查找常用字符
1.问题描述
给定仅有小写字母组成的字符串数组 A,返回列表中的每个字符串中都显示的全部字符(包括重复字符)组成的列表。例如,如果一个字符在每个字符串中出现 3 次,但不是 4 次,则需要在最终答案中包含该字符 3 次。
你可以按任意顺序返回答案。
示例 1:
输入:["bella","label","roller"]
输出:["e","l","l"]
示例 2:
输入:["cool","lock","cook"]
输出:["c","o"]
提示:
1 <= A.length <= 1001 <= A[i].length <= 100A[i][j]是小写字母
2.求解
哈希表法
- 在本题中我们需要存储所有字母在每个字符串中的出现次数,因此我们可以构造一个二维数组
- 在二维数组中用行来表示每个字符串,用列来表示每个字母。例如
int[3][2] = 2这代表c在第二个字符出现了2次 - 所以我们构造数组的大小为26列,代表26个字母,行数就是字符串数组的长度,
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;
}

给定仅有小写字母组成的字符串数组 `A`,返回列表中的每个字符串中都显示的全部字符(**包括重复字符**)组成的列表。
浙公网安备 33010602011771号