GroupAnagrams,变形词问题
2024-08-27 19:06:53
问题描述:给定一个字符串数组,返回变形词组,变形词是指字母一样但顺序不一样的词。
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;
}
}
最新文章
- jQuery-1.9.1源码分析系列(六) 延时对象应用——jQuery.ready
- 网页游戏外挂辅助AMF模拟通讯必备
- Log4j、slf4j
- JavaScript----遇到的问题
- UIWebView中Html中用JS调用OC方法及OC执行JS代码
- CSharp 调用存储过程来执行增、删、改操作
- 电子科大POJ ";3*3矩阵的乘法";
- [LeetCode] Set Mismatch 设置不匹配
- [再寄小读者之数学篇](2014-05-28 Ladyzhenskaya 不等式)
- React(五)State属性
- FAT32格式和NTFS格式区别
- POJ 1743 Musical Theme (Hash)
- [leetcode]35. Search Insert Position寻找插入位置
- 利用卷积神经网络(VGG19)实现火灾分类(附tensorflow代码及训练集)
- openstack Too many open files错误
- ionic cordova platform --help
- MongoDB-MongoDB重装系统后恢复
- Linux下搭建企业共享目录方案之------samba
- Unity Lighting - The Precompute Process 预计算过程(二)
- SLAM到底是什么?一文带你读懂SLAM
热门文章
- 前端模板<;script type=";text/template"; id=";tmpl";>;
- postgresql常用
- Less-Mixins分离规则集
- Android Download机制详解(一)DocumentUI部分
- Powershell&;.NET数值取整处理
- Cutoff frequency
- convention over configuration 约定优于配置 按约定编程 约定大于配置 PEP 20 -- The Zen of Python
- 邮件发送异常, [Errno 110] Connection timed out
- unix_timestamp 和 from_unixtime 时间戳函数 区别
- oracle在drop表时要注意