LeetCode-049-字母异位词分组
字母异位词分组
题目描述:给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。解法一:Hash判重
示例说明请见LeetCode官网。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/probl...
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
需要用hash法来判断是否是字母异位词,所以利用Hashmap
来判断排序后的字母是否相同,具体过程如下,声明一个Hashmap即tempResult来记录临时结果,其中key为字母异位词即排序相同的字母串,value为字母异位相同而排列不同的字符串集合,遍历strs:
【LeetCode-049-字母异位词分组】最后,返回tempResult的values即为最终结果。
- 首先,将当前str转换成字符数组chars,然后利用
Arrays.sort(chars)
方法将之排序,然后再将chars字符数组转变为字符串sortedStr,这个即为字母异位词转化后的相同的字符串,然后判断tempResult的key中是否存在sortedStr,如果不存在,则初始化一个List为values,将当前的str添加到list中,然后将相应的key即sortedStr和对应的values放入tempResult中;如果tempResult的key中存在sortedStr,则将当前str放入sortedStr对应的list中。然后处理下一个字符串。
import java.util.*;
public class LeetCode_049 {
public static List groupAnagrams(String[] strs) {
Map> tempResult = new HashMap<>();
for (String str : strs) {
char[] chars = str.toCharArray();
Arrays.sort(chars);
String sortedStr = String.valueOf(chars);
if (tempResult.get(sortedStr) == null) {
List values = new ArrayList<>();
values.add(str);
tempResult.put(sortedStr, values);
} else {
tempResult.get(sortedStr).add(str);
}
}
List result = new ArrayList<>();
result.addAll(tempResult.values());
return result;
}public static void main(String[] args) {
String[] strs = new String[]{"eat", "tea", "tan", "ate", "nat", "bat"};
List lists = groupAnagrams(strs);
for (List list : lists) {
for (String s : list) {
System.out.print(s + " ");
}
System.out.println();
}
}
}
【每日寄语】 生活总有不期而遇温暖和生生不息的希望,无论什么时候都要眼看前方,满怀希望就会所向披靡。
推荐阅读
- angular2内置管道
- CSS兼容性笔记
- 【golang】leetcode中级-字母异位词分组&无重复字符的最长子串
- [LeetCode]有效的字母异位词
- 【golang】leetcode初级-字符串中的第一个唯一字符&有效的字母异位词
- [Golang]力扣LeetBook—初级算法—字符串—有效的字母异位词
- 自定义View实现字母导航控件
- 打印三角型字母
- 获取字符串中每一个字母出现的次数
- 输出字母菱形