问题描述:
给你一个字符串 s ,它包含一些括号对,每个括号中包含一个 非空 的键。
比方说,字符串 “(name)is(age)yearsold” 中,有 两个 括号对,分别包含键 “name” 和 “age” 。
你知道许多键对应的值,这些关系由二维字符串数组 knowledge 表示,其中 knowledge[i] = [keyi, valuei] ,表示键 keyi 对应的值为 valuei 。
你需要替换 所有 的括号对。当你替换一个括号对,且它包含的键为 keyi 时,你需要:
将 keyi 和括号用对应的值 valuei 替换。
如果从 knowledge 中无法得知某个键对应的值,你需要将 keyi 和括号用问号 “?” 替换(不需要引号)。
knowledge 中每个键最多只会出现一次。s 中不会有嵌套的括号。
请你返回替换 所有 括号对后的结果字符串。
样例如下:
代码如下(思路在注释中):
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
public class Evaluate {public static String evaluate(String s, List>knowledge) {StringBuilder stringBuilder = new StringBuilder();
Mapmap = new HashMap<>();
for (int i = 0; i< knowledge.size(); i++) {//将knowledge中的内容存放到map中
map.put(knowledge.get(i).get(0),knowledge.get(i).get(1));
}
for (int i = 0; i< s.length(); i++) {if (s.charAt(i) == '('){//若为左括号,则向右寻找右括号的位置
int j = i;
while (s.charAt(j) != ')'){j++;
}
String temp = s.substring(i+1,j);//找到括号中的子串
stringBuilder.append(map.getOrDefault(temp, "?"));
i = j;
}else {stringBuilder.append(s.charAt(i));//若不为括号,则直接添加
}
}
return stringBuilder.toString();
}
public static void main(String[] args) {List>list = new LinkedList<>();
Listlist1 = new LinkedList<>();
list1.add("name");
list1.add("bob");
Listlist2 = new LinkedList<>();
list2.add("age");
list2.add("two");
list.add(list1);
list.add(list2);
System.out.println(evaluate("(name)is(age)yearsold",list));
}
}
运行结果如下:
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧