码迷,mamicode.com
首页 > 其他好文 > 详细

49. Group Anagrams

时间:2019-02-03 10:56:04      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:for   out   ram   实现   list()   toc   bat   har   add   

Given an array of strings, group anagrams together.

Example:

Input: ["eat", "tea", "tan", "ate", "nat", "bat"],
Output:
[
  ["ate","eat","tea"],
  ["nat","tan"],
  ["bat"]
]

Note:

  • All inputs will be in lowercase.
  • The order of your output does not matter.
    class Solution {
        public List<List<String>> groupAnagrams(String[] strs) {
            // if (strs.length == 0) return new ArrayList();
            // Map<String, List> ans = new HashMap<String, List>();
            // for (String s : strs) {
            //     char[] ca = s.toCharArray();
            //     Arrays.sort(ca);
            //     String key = String.valueOf(ca);
            //     if (!ans.containsKey(key)) ans.put(key, new ArrayList());
            //     ans.get(key).add(s);
            // }
            // return new ArrayList(ans.values());
            if(strs.length == 0) return new ArrayList();
            Map<String, List> ans = new HashMap<String, List>();
            for(String s : strs){
                char[] ca = s.toCharArray();
                Arrays.sort(ca);
                String key = String.valueOf(ca);
                if(!ans.containsKey(key)) ans.put(key, new ArrayList());
                ans.get(key).add(s);
            }
            return new ArrayList(ans.values());
        }
    }

    能想到类似的方法,但是脑子里面的API不够实现,所以之后多记一些API。

  另:

  再来看一种方法,不用sort,用一个长度为26的int数组来存放各char出现的次数,不过一顿操作0-5,本质上还是一种又臭又长的方法

class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        if (strs.length == 0) return new ArrayList();
        Map<String, List> ans = new HashMap<String, List>();
        int[] count = new int[26];
        for (String s : strs) {
            Arrays.fill(count, 0);
            for (char c : s.toCharArray()) count[c - ‘a‘]++;

            StringBuilder sb = new StringBuilder("");
            for (int i = 0; i < 26; i++) {
                sb.append(‘#‘);
                sb.append(count[i]);
            }
            String key = sb.toString();
            if (!ans.containsKey(key)) ans.put(key, new ArrayList());
            ans.get(key).add(s);
        }
        return new ArrayList(ans.values());
    }
}

 

49. Group Anagrams

标签:for   out   ram   实现   list()   toc   bat   har   add   

原文地址:https://www.cnblogs.com/wentiliangkaihua/p/10349564.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!