首页 > 其他 > 详细

查找常用字符

时间:2020-10-15 22:25:48      阅读:33      评论:0      收藏:0      [点我收藏+]

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;
    }

查找常用字符

原文:https://www.cnblogs.com/g9420/p/13821074.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!