题目是:求字符串S中 包含 字符串J中的字母的个数,区分大小写。
比如
Input: J = "aA", S = "aAAbbbb" Output: 3
Input: J = "z", S = "ZZ"
Output: 0
最简洁的代码如下,但是执行速度比下面for循环实现的慢:
S.replaceAll("[^" + J + "]", "").length();
其中 [^ ] 是正则表达式。
[] 匹配列表之中的任何单个字符. 例如, "[ab]" 匹配 "a" 或者 "b". "[0-9]" 匹配任意数字.
[^] 匹配列表之外的任何单个字符. 例如, "[^ab]" 匹配 "a" 和 "b" 以外的字符. "[^0-9]" 匹配任意非数字字符.
更多正则表达式,参考链接:
https://yelinsen.iteye.com/blog/854092
不太会用正则表达,那就for循环:
class Solution {
public int numJewelsInStones(String J, String S) {
int res = 0;
for (char s: S.toCharArray()){
if (J.contains(s+"")){
res++;
}
}
return res;
}
}