[Leetcode]-- Anagrams

Given an array of strings, return all groups of strings that are anagrams.
Note: All inputs will be in lower-case.
 

思路:map<string, int>记录排序后的字符串以及首次出现的位置。

1. 从strs的第一个元素开始遍历,首先对元素进行排序得到s

2. 在map里查找s

3. 若不存在,将s以及该元素的下标存入map<string ,int>

4. 若存在,首先将第一次出现s时的原始字符串存入结果res,即strs[map[s]],并将map[s]设置为-1(防止下次再存),再将该字符串本身存入结果res

5. 重复以上1-4步,直到遍历结束。

 

 

 
[Leetcode]-- Anagrams
public class Solution {
    public  String sortChars(String s) {
        char[] content = s.toCharArray();
        Arrays.sort(content);
        return new String(content);
    }   

    public ArrayList<String> anagrams(String[] strs) {
        ArrayList<String> res = new ArrayList<String>();
        HashMap<String, LinkedList<String>> hash = new HashMap<String, LinkedList<String>>();
     
        /* Group words by anagram */
        for (String s : strs) {
            String key = sortChars(s); 
            if (!hash.containsKey(key)) {
                hash.put(key, new LinkedList<String>());
            }   
            LinkedList<String> anagrams = hash.get(key);
            anagrams.push(s);
        } 
        for (String key : hash.keySet()) {
            LinkedList<String> list = hash.get(key);
            if (list.size() > 1) {
                for (String t : list) {
                    res.add(t);
                }   
            }
        }   
        return res;
    }
}
[Leetcode]-- Anagrams

 

 

[Leetcode]-- Anagrams

上一篇:LINUX 下 NMAP 内网扫描


下一篇:Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用