Loading

查找常用字符

1.问题描述

给定仅有小写字母组成的字符串数组 A,返回列表中的每个字符串中都显示的全部字符(包括重复字符)组成的列表。例如,如果一个字符在每个字符串中出现 3 次,但不是 4 次,则需要在最终答案中包含该字符 3 次。

你可以按任意顺序返回答案。

示例 1:

输入:["bella","label","roller"]
输出:["e","l","l"]

示例 2:

输入:["cool","lock","cook"]
输出:["c","o"]

提示:

  1. 1 <= A.length <= 100
  2. 1 <= A[i].length <= 100
  3. A[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;
    }
posted @ 2020-10-15 15:55  水纸杯  阅读(120)  评论(0)    收藏  举报