leetcode.1002. 查找常用字符

给定仅有小写字母组成的字符串数组 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] 是小写字母

解题思路:题意理解起来很好理解,解决方法也比较容易,但是处理起来就比较麻烦,这道题目实际上是要找出每个字符在字符串数组的每个字符串中出现的最小次数,例如实例1各个字符在每个字符串中出现的次数如下,每个字符取最小的出现次数,添加到结果集,最后得到所求结果e l l。

输入:["bella","label","roller"]
输出:["e","l","l"]
key: a value:   1  1  0
key: b value:   1  1  0
key: r value:   0  0  2
key: e value:   1  1  1
key: l value:   2  2  2
key: o value:   0  0  1
result:  e l l

代码:

public List<String> commonChars(String[] a) {
		List<String> s = new ArrayList<>();//定义返回数组
		Map<Character,int[]> map = new HashMap<>();//定义字符出现次数结果集
		int lena = a.length;
		for(int i=0;i<lena;i++) {
			char c[] = a[i].toCharArray();//字符串转换成字符数组
			for(int j=0;j<c.length;j++) {
				int[] ans = new int[lena];//存未出现过的字符次数集合
				int[] anp = map.get(c[j]);//获取已出现过的字符次数集合
				if(anp!=null) {
					if(anp[i]>0){
						anp[i] = anp[i]+1;//累加次数
						map.put(c[j], anp);
					}else {
						anp[i] = 1;//未出现,初始化为1
						map.put(c[j], anp);
					}
				}else {
					ans[i] = 1;//未出现,初始化为1
					map.put(c[j], ans);
				}
			}
		}
		Iterator iter = map.entrySet().iterator();
		while (iter.hasNext()) {
			Map.Entry entry = (Map.Entry) iter.next();
			Character key = (Character) entry.getKey();
			int[] val = (int[]) entry.getValue();
			//System.out.print("key: "+key+" value: ");
			int min=Integer.MAX_VALUE;
			for(int i=0;i<val.length;i++) {
				//System.out.print("  "+val[i]);
				if(val[i]<min)min=val[i];//取最小出现次数
			}
			for(int i=0;i<min;i++) {
				s.add(key.toString());//添加进结果集
			}
			//System.out.println();
		}
		return s;
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AcLings

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值