leetcode 49. Group Anagrams

leetcode  49. Group Anagrams



很久·没刷leetcode,逐渐手生了。

下面的代码不知道为何不能acc

错误为:


public class Solution {
	Set<Character> genCharSet(String s){
		Set<Character> res =  new HashSet<Character>();
		for(int i=0;i<s.length();i++){
			res.add(s.charAt(i));
		}
		return res;
	}

	public List<List<String>> groupAnagrams(String[] strs) {
    	List<Set<Character>> arr = new ArrayList<Set<Character>>();
    	List<List<String>> res = new ArrayList<List<String>>();
    	for(String s:strs){
    		Set<Character> sset = genCharSet(s);
    		
    		if(arr.contains(sset)){
    			res.get(arr.indexOf(sset)).add(s);
    		}else{
    			arr.add(sset);
    			res.add(new ArrayList<String>());
    			res.get(arr.indexOf(sset)).add(s);
    		}
    	}
    	return res;
    }
	
	
	public static void main(String[] args){
		Solution s = new Solution();
		String[] strs = {""};
		s.groupAnagrams(strs);
	}
}



Solution 里提供的答案,利用质数来求解,很巧妙地说


public static List<List<String>> groupAnagrams(String[] strs) { 
   int[] prime = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103};//最多10609个z
    
            List<List<String>> res = new ArrayList<>();
            HashMap<Integer, Integer> map = new HashMap<>();
            for (String s : strs) {
                int key = 1;
                for (char c : s.toCharArray()) {
                    key *= prime[c - 'a'];
                }
                List<String> t;
                if (map.containsKey(key)) {
                    t = res.get(map.get(key));
                } else {
                    t = new ArrayList<>();
                    res.add(t);
                    map.put(key, res.size() - 1);
                }
                t.add(s);
            }
            return res;
    }



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值
>