87 lines
2.8 KiB
Java
87 lines
2.8 KiB
Java
|
package hash;
|
|||
|
|
|||
|
import java.util.ArrayList;
|
|||
|
import java.util.Arrays;
|
|||
|
import java.util.HashMap;
|
|||
|
import java.util.List;
|
|||
|
|
|||
|
/**
|
|||
|
* 题目:49.字母异位词分组 (groupAnagrams)
|
|||
|
* 描述:给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
|
|||
|
* 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
|
|||
|
* 链接:https://leetcode.cn/problems/group-anagrams
|
|||
|
*
|
|||
|
示例 1:
|
|||
|
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
|
|||
|
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]
|
|||
|
|
|||
|
示例 2:
|
|||
|
输入: strs = [""]
|
|||
|
输出: [[""]]
|
|||
|
|
|||
|
示例 3:
|
|||
|
输入: strs = ["a"]
|
|||
|
输出: [["a"]]
|
|||
|
*/
|
|||
|
|
|||
|
//做出来了。
|
|||
|
public class GroupAnagrams {
|
|||
|
//计数
|
|||
|
public List<List<String>> groupAnagrams1(String[] strs) {
|
|||
|
// 创建一个 Map,键是编码后的字符串,值是字母异位词列表
|
|||
|
HashMap<String, List<String>> map = new HashMap<>();
|
|||
|
|
|||
|
// 遍历输入数组
|
|||
|
for (String str : strs) {
|
|||
|
// 统计每个字母出现的次数
|
|||
|
int[] count = new int[26];
|
|||
|
for (char c : str.toCharArray()) {
|
|||
|
count[c - 'a']++; // 统计字母出现次数
|
|||
|
}
|
|||
|
|
|||
|
// 将字母统计结果编码为字符串
|
|||
|
StringBuilder sb = new StringBuilder();
|
|||
|
for (int i = 0; i < 26; i++) {
|
|||
|
sb.append('#'); //必须加 [bdddddddddd, bbbbbbbbbbc] 都是01010... 01010...
|
|||
|
sb.append(count[i]);
|
|||
|
}
|
|||
|
String key = sb.toString();
|
|||
|
|
|||
|
// 如果 Map 中不存在该键,则创建一个新的列表
|
|||
|
if (!map.containsKey(key)) {
|
|||
|
map.put(key, new ArrayList<>());
|
|||
|
}
|
|||
|
|
|||
|
// 将当前单词添加到对应的列表中
|
|||
|
map.get(key).add(str);
|
|||
|
}
|
|||
|
|
|||
|
// 返回 Map 中的所有值(即字母异位词列表)
|
|||
|
return new ArrayList<>(map.values());
|
|||
|
}
|
|||
|
//排序
|
|||
|
public List<List<String>> groupAnagrams(String[] strs) {
|
|||
|
// 创建一个 Map,键是标准化后的字符串,值是字母异位词列表
|
|||
|
HashMap<String, List<String>> map = new HashMap<>();
|
|||
|
|
|||
|
// 遍历输入数组
|
|||
|
for (String str : strs) {
|
|||
|
// 将单词转换为字符数组并排序
|
|||
|
char[] charArray = str.toCharArray();
|
|||
|
Arrays.sort(charArray);
|
|||
|
String sortedStr = new String(charArray);
|
|||
|
|
|||
|
// 如果 Map 中不存在该键,则创建一个新的列表
|
|||
|
if (!map.containsKey(sortedStr)) {
|
|||
|
map.put(sortedStr, new ArrayList<>());
|
|||
|
}
|
|||
|
|
|||
|
// 将当前单词添加到对应的列表中
|
|||
|
map.get(sortedStr).add(str);
|
|||
|
}
|
|||
|
|
|||
|
// 返回 Map 中的所有值(即字母异位词列表)
|
|||
|
return new ArrayList<>(map.values());
|
|||
|
}
|
|||
|
}
|