LeetCode-049-字母异位词分组

字母异位词分组

题目描述:给定一个字符串数组,将字母异位词组合在一块儿。字母异位词指字母相同,但排列不一样的字符串。java

示例说明请见LeetCode官网。segmentfault

来源:力扣(LeetCode)
连接:https://leetcode-cn.com/probl...
著做权归领扣网络全部。商业转载请联系官方受权,非商业转载请注明出处。数组

解法一:Hash判重

须要用hash法来判断是不是字母异位词,因此利用Hashmap来判断排序后的字母是否相同,具体过程以下,声明一个Hashmap即tempResult来记录临时结果,其中key为字母异位词即排序相同的字母串,value为字母异位相同而排列不一样的字符串集合,遍历strs:网络

  • 首先,将当前str转换成字符数组chars,而后利用Arrays.sort(chars)方法将之排序,而后再将chars字符数组转变为字符串sortedStr,这个即为字母异位词转化后的相同的字符串,而后判断tempResult的key中是否存在sortedStr,若是不存在,则初始化一个List为values,将当前的str添加到list中,而后将相应的key即sortedStr和对应的values放入tempResult中;若是tempResult的key中存在sortedStr,则将当前str放入sortedStr对应的list中。而后处理下一个字符串。

最后,返回tempResult的values即为最终结果。url

import java.util.*;

public class LeetCode_049 {
    public static List<List<String>> groupAnagrams(String[] strs) {
        Map<String, List<String>> 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<String> values = new ArrayList<>();
                values.add(str);
                tempResult.put(sortedStr, values);
            } else {
                tempResult.get(sortedStr).add(str);
            }
        }
        List<List<String>> 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<List<String>> lists = groupAnagrams(strs);
        for (List<String> list : lists) {
            for (String s : list) {
                System.out.print(s + " ");
            }
            System.out.println();
        }
    }
}
【每日寄语】 生活总有不期而遇温暖和生生不息的但愿,不管何时都要眼看前方,满怀但愿就会所向披靡。
相关文章
相关标签/搜索