查找常用字符

时间:2020-10-15 22:25:48   收藏:0   阅读:39

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.求解

哈希表法

代码如下

    /*
    * 执行用时: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

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!