问题描述
在广告平台中,为了给广告主一定的自由性和效率,允许广告主在创造标题的时候以通配符的方式进行创意提交。线上服务的时候,会根据用户的搜索词触发的 bidword 对创意中的通配符(通配符是用成对 {} 括起来的字符串,可以包含 0 个或者多个字符)进行替换,用来提升广告投放体验。例如:“{末日血战} 上线送 SSR 英雄,三天集齐无敌阵容!”,会被替换成“帝国时代游戏下载上线送 SSR 英雄,三天集齐无敌阵容!”。给定一个含有通配符的创意和n个标题,判断这句标题是否从该创意替换生成的。
输入描述与输出要求
- 输入参数:
n:一个整数,表示标题的数量。template:一个字符串,表示含有通配符的广告创意模板。titles:一个字符串数组,包含n个标题,这些标题需要被验证是否可以通过替换template中的通配符生成。
- 输出参数:
- 输出一个字符串,包含
n个布尔值,用逗号分隔,表示每个标题是否可以通过替换template中的通配符生成。
- 输出一个字符串,包含
算法逻辑详解
-
通配符转换:
- 算法首先遍历
template字符串,当遇到通配符(即大括号{}包围的字符串)时,将其替换为正则表达式中的.*,这表示任意长度的任意字符。这一步是必要的,因为通配符在广告创意中代表可以被任意字符串替换的部分。 - 例如,如果
template为"ad{xyz}cdc{y}f{x}e",则算法会将其转换为正则表达式"ad.*cdc.y.f.x.e"。
- 算法首先遍历
-
构建正则表达式:
- 利用转换后的字符串构建一个正则表达式,该正则表达式将用于匹配
titles中的标题。这一步是算法的核心,因为它决定了哪些标题可以通过替换生成。
- 利用转换后的字符串构建一个正则表达式,该正则表达式将用于匹配
-
匹配验证:
- 对于
titles中的每个标题,使用构建的正则表达式进行匹配,检查标题是否符合模板。这一步是验证过程的关键,它直接决定了输出结果的正确性。
- 对于
-
结果输出:
- 将匹配结果转换为布尔值字符串,并用逗号分隔。这一步是输出格式化的过程,确保结果的可读性和易用性。
代码实现与分析
以下是Java语言的实现代码,该代码详细实现了上述算法逻辑:
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
public class Main {
public static String solution(int n, String template, String[] titles) {
StringBuilder regexPattern = new StringBuilder();
int i = 0;
// 遍历模板,构建正则表达式
while (i < template.length()) {
if (template.charAt(i) == '{') {
// 找到通配符开始
i++;
while (i < template.length() && template.charAt(i) != '}') {
i++;
}
// 包含通配符,转换为 .*
regexPattern.append(".*");
} else {
regexPattern.append(Pattern.quote(String.valueOf(template.charAt(i)))); // 转义非通配符字符
}
i++;
}
// 使用正则表达式进行匹配
Pattern regex = Pattern.compile("^" + regexPattern.toString() + "$"); // 全匹配
List<Boolean> results = new ArrayList<>();
for (String title : titles) {
Matcher matcher = regex.matcher(title);
results.add(matcher.matches());
}
// 将 results 列表转换为逗号分隔的字符串
StringBuilder resultsStr = new StringBuilder();
for (int j = 0; j < results.size(); j++) {
resultsStr.append(results.get(j) ? "True" : "False");
if (j < results.size() - 1) {
resultsStr.append(",");
}
}
return resultsStr.toString();
}
public static void main(String[] args) {
// 测试用例
String[] testTitles1 = {"adcdcefdfeffe", "adcdcefdfeff", "dcdcefdfeffe", "adcdcfe"};
String[] testTitles2 = {"CLSomGhcQNvFuzENTAMLCqxBdj", "CLSomNvFuXTASzENTAMLCqxBdj", "CLSomFuXTASzExBdj", "CLSoQNvFuMLCqxBdj", "SovFuXTASzENTAMLCq", "mGhcQNvFuXTASzENTAMLCqx"};
String[] testTitles3 = {"abcdefg", "abefg", "efg"};
System.out.println(solution(4, "ad{xyz}cdc{y}f{x}e", testTitles1));
System.out.println(solution(6, "{xxx}h{cQ}N{vF}u{XTA}S{NTA}MLCq{yyy}", testTitles2));
System.out.println(solution(3, "a{bdc}efg", testTitles3));
}
}
测试用例分析
- 测试用例1:
template为"ad{xyz}cdc{y}f{x}e",titles为{"adcdcefdfeffe", "adcdcefdfeff", "dcdcefdfeffe", "adcdcfe"}。输出结果为"True,False,False,False",表示只有第一个标题可以通过替换生成。这个测试用例展示了算法能够正确识别哪些标题是通过替换通配符生成的。 - 测试用例2:
template为"{xxx}h{cQ}N{vF}u{XTA}S{NTA}MLCq{yyy}",titles为{"CLSomGhcQNvFuzENTAMLCqxBdj", "CLSomNvFuXTASzENTAMLCqxBdj", "CLSomFuXTASzExBdj", "CLSoQNvFuMLCqxBdj", "SovFuXTASzENTAMLCq", "mGhcQNvFuXTASzENTAMLCqx"}。输出结果为"True,True,True,True,False,False",表示前四个标题可以通过替换生成。这个测试用例展示了算法对于复杂模板的处理能力。 - 测试用例3:
template为"a{bdc}efg",titles为{"abcdefg", "abefg", "efg"}。输出结果为"True,True,False",表示前两个标题可以通过替换生成。这个测试用例展示了算法对于简单模板的处理能力。
通过这个算法,我们可以有效地验证广告标题是否由给定的广告创意模板生成,从而确保广告投放的准确性和相关性。这个算法的实现不仅提高了广告投放的效率,还增强了广告的个性化体验。