zoukankan      html  css  js  c++  java
  • GroupAnagrams,变形词问题

    问题描述:给定一个字符串数组,返回变形词组,变形词是指字母一样但顺序不一样的词。

    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;
        }
    }
    
  • 相关阅读:
    通过mixins方法处理调取服务器时间
    记录个人对vuex的简单理解
    利用弹性布局实现垂直居中
    vue.set的适用方法
    深拷贝和浅拷贝的实现方法
    Maven安装步骤
    build tools
    Git
    Url和Uri的区别
    函数式编程语言
  • 原文地址:https://www.cnblogs.com/masterlibin/p/5752874.html
Copyright © 2011-2022 走看看