题目:

Given an array of strings, return all groups of strings that are anagrams.

Note: All inputs will be in lower-case.

Hide Tags

Hash Table String 

链接:  http://leetcode.com/problems/anagrams/

题解:

求String数组里所有的异位构词anagram。比如"abcde"和"edcba"算是anagrams,"12345"和"54321"。结果要求返回所有的anagrams在一个ArrayList里,所以我们例子里的结果就是{"abcde", "edcba","12345","54321"}。原理是利用一个HashMap存储String key以及ArrayList<String> value。 Key是排序好的string,比如"abcde"和"edcba"排序后都是"abcde",所以他们都属于同一组anagrams。对于排序后的string,已经在HashMap里存在key的,我们把排序前的原string加入到结果里。当HashMap里存在key而且value.size()为1时,我们要把第一个未排序的string先存入结果。 当HashMap里不存在key,我们要建立这个<key,value>pair。时间复杂度主要在于要对n个string,每个string转换为array之后进行排序,java的Arrays.sort()对于数组的话是使用merge sort,所以时间复杂度是O(n * mlogm),m是每个string的平均长度。空间复杂度的话我们使用了HashMap,临时数组可以不考虑,所以主要是O(n * m)。

Time Complexity - O(n * mlogm),Space Complexity - O(n * m),where m is average length of elements in strs。

public class Solution {
public ArrayList<String> anagrams(String[] strs) {
ArrayList<String> result = new ArrayList<String>();
if(strs == null || strs.length == 0)
return result;
HashMap<String, ArrayList<String>> map = new HashMap<String, ArrayList<String>>(); for(int i = 0; i < strs.length; i++){
char[] arr = strs[i].toCharArray();
Arrays.sort(arr);
String sortedStr = String.valueOf(arr);
if(map.containsKey(sortedStr)){
if(map.get(sortedStr).size() == 1)
result.add(map.get(sortedStr).get(0));
map.get(sortedStr).add(strs[i]);
result.add(strs[i]);
} else {
ArrayList<String> list = new ArrayList<String>();
list.add(strs[i]);
map.put(sortedStr, list);
}
} return result;
}
}

更新:  Group anagrams

public class Solution {
public List<List<String>> groupAnagrams(String[] strs) {
List<List<String>> res = new ArrayList<>();
if(strs == null || strs.length == 0)
return res;
HashMap<String, ArrayList<String>> map = new HashMap<>();
Arrays.sort(strs); for(String str : strs) {
char[] arr = str.toCharArray();
Arrays.sort(arr);
String sortedStr = new String(arr);
if(!map.containsKey(sortedStr)) {
ArrayList<String> list = new ArrayList<>();
list.add(str);
map.put(sortedStr, list);
} else {
map.get(sortedStr).add(str);
}
} for(String str : map.keySet())
res.add(map.get(str)); return res;
}
}

二刷:

现在这道题已经改名叫Group Anagrams了,还加了例子。好人性化的感觉。主要思路还是和一刷一样,对每一个Strs里面的字符串,先生成排序后的新字符串key,然后根据key保存到hashmap里。最后遍历hashmap把结果放在List里。

看了discuss从wz366看到可以直接把map的values转化为结果 -  return new ArrayList<List<String>>(map.values());

Given an array of strings, group anagrams together.

For example, given: ["eat", "tea", "tan", "ate", "nat", "bat"]
Return:

[
["ate", "eat","tea"],
["nat","tan"],
["bat"]
]

Note:

  1. For the return value, each inner list's elements must follow the lexicographic order.
  2. All inputs will be in lower-case.

Java:

Time Complexity - O(n * mlogm) , Space Complexity - O(m * n),  m为字符串的平均长度

public class Solution {
public List<List<String>> groupAnagrams(String[] strs) {
List<List<String>> res = new ArrayList<>();
if (strs == null || strs.length == 0) {
return res;
}
Map<String, List<String>> map = new HashMap<>();
for (String s : strs) {
char[] arr = s.toCharArray();
Arrays.sort(arr);
String key = new String(arr);
if (map.containsKey(key)) {
map.get(key).add(s);
} else {
List<String> tmp = new ArrayList<>();
tmp.add(s);
map.put(key, tmp);
}
} List<String> anagrams = new ArrayList<>();
for (String str : map.keySet()) {
anagrams = map.get(str);
Collections.sort(anagrams);
res.add(anagrams);
}
return res;
}
}

或者

public class Solution {
public List<List<String>> groupAnagrams(String[] strs) {
List<List<String>> res = new ArrayList<>();
if (strs == null || strs.length == 0) {
return res;
}
Arrays.sort(strs);
Map<String, List<String>> map = new HashMap<>();
for (String s : strs) {
char[] arr = s.toCharArray();
Arrays.sort(arr);
String key = new String(arr);
if (map.containsKey(key)) {
map.get(key).add(s);
} else {
List<String> tmp = new ArrayList<>();
tmp.add(s);
map.put(key, tmp);
}
}
return new ArrayList<List<String>>(map.values());
}
}

三刷:

方法和前两刷一样。这里先对strs数组进行排序,最后可以一次性返回new ArrayList<List<String>>(map.values);

这样写速度并不快。我们也可以先不排序,计算完hashmap以后, 在遍历hashMap将其每个key对应的values加入到res的时候进行排序。这样的话速度可以增快不少。也就是说跟二刷的第一段代码差不多。

Java:

public class Solution {
public List<List<String>> groupAnagrams(String[] strs) {
List<List<String>> res = new ArrayList<>();
if (strs == null) return res;
Arrays.sort(strs);
Map<String, List<String>> map = new HashMap<>();
for (String s : strs) {
char[] sArr = s.toCharArray();
Arrays.sort(sArr);
String key = String.valueOf(sArr);
if (!map.containsKey(key)) map.put(key, new ArrayList<String>());
map.get(key).add(s);
}
return new ArrayList<>(map.values());
}
}

Reference:

https://leetcode.com/discuss/58561/share-my-short-java-solution

https://leetcode.com/discuss/51190/1-line-ruby-python-for-updated-problem

49. Anagrams的更多相关文章

  1. [Leetcode][Python]49: Anagrams

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 49: Anagramshttps://leetcode.com/proble ...

  2. Leetcode#49 Anagrams

    原题地址 Anagram:变位词.两个单词是变位词关系的条件是:组成单词的字符相同,只是顺序不同 第一次看这道题看了半天没明白要干嘛,丫就不能给个样例输入输出么..后来还是看网上其他人的总结知道是怎么 ...

  3. 【LeetCode】49. Anagrams (2 solutions)

    Anagrams Given an array of strings, return all groups of strings that are anagrams. Note: All inputs ...

  4. LeetCode All in One 题目讲解汇总(持续更新中...)

    终于将LeetCode的免费题刷完了,真是漫长的第一遍啊,估计很多题都忘的差不多了,这次开个题目汇总贴,并附上每道题目的解题连接,方便之后查阅吧~ 477 Total Hamming Distance ...

  5. LeetCode 刷题顺序表

    Id Question Difficulty Frequency Data Structures Algorithms 1 Two Sum 2 5 array + set sort + two poi ...

  6. LeetCode Question Difficulty Distribution

    参考链接:https://docs.google.com/spreadsheet/pub?key=0Aqt--%20wSNYfuxdGxQWVFsOGdVVWxQRlNUVXZTdEpOeEE& ...

  7. leetcode难度及面试频率

    转载自:LeetCode Question Difficulty Distribution                 1 Two Sum 2 5 array sort           set ...

  8. Leetcode难度表及解题汇总

    Leetcode难度表及解题汇总 参考网上一份题目难度表,以及本人的解题. Id Question Difficulty Frequency Data Structures Algorithms Bl ...

  9. leetcode刷题指南

    转载自:http://blog.csdn.net/lnho2015/article/details/50962989 以下是我个人做题过程中的一些体会: 1. LeetCode的题库越来越大,截止到目 ...

随机推荐

  1. Delphi 中的全局快捷键+给指定窗体发送按键

    [背景] 公司做视频影像采集,平时采集图像的时候都需要打开采集窗口,然后需要开着采集窗口来进行图像采集.同事问我能不能做一个全局快捷键,哪怕我没有操作也可以采集图像.说干就干,一直想做全局快捷键了,网 ...

  2. mac os去除去除.DS_Store文件--使用python和go(原创)

    .DS_Store (英文全称 Desktop Services Store)是一种由苹果公司的Mac OS X操作系统所创造的隐藏文件,目的在于存贮文件夹的自定义属性,例如文件们的图标位置或者是背景 ...

  3. ASP.NET Web - 服务器控件

    控件 HTML 说明 Label <span> 返回一个包含文本的span元素 Literal static text 返回简单的静态文本.使用Literal控件,可以根据客户应用程序转换 ...

  4. 利用QObject反射实现jsonrpc

    1.jsonrpc请求中的params数组生成签名 static QString signatureFromJsonArray(const QJsonArray &array) { QStri ...

  5. OC面向对象多态笔记

    面向对象的多态是建立在继承上,可以说没有继承就没有多态: 多态:父类指针指向了子类的对象: int main() { //假设已定义了Animal类和它的子类Dog,那么多态的代码体现就是 Anima ...

  6. android开发 socket接收图片并保存

    逻辑:接收到socket之后需要将socket发送的图片数据保存下来并通知handler更新界面 关键代码: public void readImage(Socket socket) { try { ...

  7. EntityFramework Add方法与Attach区别

    一 先发问. 问题:在使用EF过程中,能否有一个方法可以直接执行传入的SQL语句.纠结的只找到了调用存储过程的方法,难道要SqlHelper.cs?    二 友情提示 本文内容参考自MSDN. 三 ...

  8. Matlab实现求a到b被c整除的个数

    我先想到的是for循环........ 然后sum(find(mod(a:b,c)==0)),从10到100得到874,为什么不对呢? 比如a = [1 2 3 4  2 3 4 2],find(a= ...

  9. SQL Server 之 校对

    _CI(CS) 是否区分大小写,CI不区分,CS区分 _AI(AS) 是否区分重音,AI不区分,AS区分 _KI(KS) 是否区分假名类型,KI不区分,KS区分 _WI(WS) 是否区分宽度 WI不区 ...

  10. 电脑问题交流QQ群

    各种电脑问题交流QQ群号 164853622 系统重装 系统恢复 系统出问题 电脑主页 修改 主页 搜狗 软件卸载 顽固 病毒 讨论