问题描述:给定一个字符串数组,返回变形词组,变形词是指字母一样但顺序不一样的词。

Given an array of strings, group anagrams together.

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

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

算法分析:可以用字符串本身字符进行排序,然后得到新的字符串,如果是变形词,那么排序后的字符串相同,可以把这相同的排序结果当做map的key,而把变形词当做map的value。

public class GroupAnagrams {
public List<List<String>> groupAnagrams(String[] strs) {
Map<String, List<String>> map = new HashMap<>();
for(String str : strs)
{
char[] chr = str.toCharArray();
Arrays.sort(chr);//对字符串排序
String key = new String(chr);
List<String> list = map.get(key);
if(list == null)
{
list = new ArrayList<>();
}
list.add(str);
map.put(key, list);
}
List<List<String>> list = new ArrayList<>();
for(String key : map.keySet())
{
List<String> curr = map.get(key);
Collections.sort(curr);//对list排序
list.add(curr);
}
return list;
}
}

最新文章

  1. jQuery-1.9.1源码分析系列(六) 延时对象应用——jQuery.ready
  2. 网页游戏外挂辅助AMF模拟通讯必备
  3. Log4j、slf4j
  4. JavaScript----遇到的问题
  5. UIWebView中Html中用JS调用OC方法及OC执行JS代码
  6. CSharp 调用存储过程来执行增、删、改操作
  7. 电子科大POJ &quot;3*3矩阵的乘法&quot;
  8. [LeetCode] Set Mismatch 设置不匹配
  9. [再寄小读者之数学篇](2014-05-28 Ladyzhenskaya 不等式)
  10. React(五)State属性
  11. FAT32格式和NTFS格式区别
  12. POJ 1743 Musical Theme (Hash)
  13. [leetcode]35. Search Insert Position寻找插入位置
  14. 利用卷积神经网络(VGG19)实现火灾分类(附tensorflow代码及训练集)
  15. openstack Too many open files错误
  16. ionic cordova platform --help
  17. MongoDB-MongoDB重装系统后恢复
  18. Linux下搭建企业共享目录方案之------samba
  19. Unity Lighting - The Precompute Process 预计算过程(二)
  20. SLAM到底是什么?一文带你读懂SLAM

热门文章

  1. 前端模板&lt;script type=&quot;text/template&quot; id=&quot;tmpl&quot;&gt;
  2. postgresql常用
  3. Less-Mixins分离规则集
  4. Android Download机制详解(一)DocumentUI部分
  5. Powershell&amp;.NET数值取整处理
  6. Cutoff frequency
  7. convention over configuration 约定优于配置 按约定编程 约定大于配置 PEP 20 -- The Zen of Python
  8. 邮件发送异常, [Errno 110] Connection timed out
  9. unix_timestamp 和 from_unixtime 时间戳函数 区别
  10. oracle在drop表时要注意