给定仅有小写字母组成的字符串数组 A
,返回列表中的每个字符串中都显示的全部字符(包括重复字符)组成的列表。例如,如果一个字符在每个字符串中出现 3 次,但不是 4 次,则需要在最终答案中包含该字符 3 次。
你可以按任意顺序返回答案。
示例 1:
输入:["bella","label","roller"]
输出:["e","l","l"]
示例 2:
输入:["cool","lock","cook"]
输出:["c","o"]
提示:
1 <= A.length <= 100
1 <= A[i].length <= 100
A[i][j]
是小写字母int[3][2] = 2
这代表c在第二个字符出现了2次new int[length][26]
代码如下
/*
* 执行用时:4 ms, 在所有 Java 提交中击败了71.56% 的用户
* 内存消耗:38.7 MB, 在所有 Java 提交中击败了95.67% 的用户
* */
public List<String> commonChars(String[] A) {
int[][] strNums = new int[A.length][26];
for (int i = 0; i < A.length; i++) {
for (char s : A[i].toCharArray()) {
strNums[i][s - ‘a‘] = strNums[i][s - ‘a‘] + 1;
}
}
List<String> list = new ArrayList<>(26);
for (int i = 0; i < 26; i++) {
int min = Integer.MAX_VALUE;
for (int j = 0; j < A.length; j++) {
min = Math.min(strNums[j][i], min);
}
for (int j = 0; j < min; j++) {
list.add(String.valueOf((char)(‘a‘ + i)));
}
}
return list;
}
原文:https://www.cnblogs.com/g9420/p/13821074.html