1. 给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
    2. 字母异位词 是由重新排列源单词的字母得到的一个新单词,所有源单词中的字母通常恰好只用一次。
    3. 示例 1:
    4. 输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
    5. 输出: [["bat"],["nat","tan"],["ate","eat","tea"]]
    6. 示例 2:
    7. 输入: strs = [""]
    8. 输出: [[""]]
    9. 提示:
    10. 1 <= strs.length <= 104
    11. 0 <= strs[i].length <= 100
    12. strs[i] 仅包含小写字母
    1. class Solution {
    2. public List<List<String>> groupAnagrams(String[] strs) {
    3. Map<String, List<String>> map =
    4. new HashMap<String, List<String>>();
    5. for (String str : strs) {
    6. char[] array = str.toCharArray();
    7. Arrays.sort(array);
    8. String key = new String(array);
    9. List<String> list =
    10. map.getOrDefault(key, new ArrayList<String>());
    11. list.add(str);
    12. map.put(key, list);
    13. }
    14. return new ArrayList<List<String>>(map.values());
    15. }
    16. }