算法升级之路(三)

字母异位词分组

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

示例 1:

输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]

输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

解题思路

最容易想到的是:从第一个字符串开始,把字符串中的字符放入map中,然后循环比较每一个字符串的字符是不是在map中存在,

但是有几个问题难以解决

  1. 查找出来的属于字母异位词的,没有办法去除,因为数组去除元素比较复杂
  2. 占空间大,每一个字符串都要声明一个map来存

排序法:

字母异位词 他们包含的字符都是相等的,那经过排序之后的字符串也肯定相等,然后将他们放到map<String,List>,最后将map中所有的value取到即可。

java 复制代码
 public List<List<String>> groupAnagrams(String[] strs) {
        Map <String,List<String>> map = new HashMap <String,List<String>> ();
        if(strs.length==0){
            return new ArrayList<List<String>>();
        }
        List<List<String>> resList = new ArrayList();
        for(int i=0;i<strs.length;i++){
            char []array = strs[i].toCharArray();
            Arrays.sort(array);
            String key = new String (array);
            List<String> list=map.getOrDefault(key,new ArrayList<String>());
            list.add(strs[i]);
            map.put(key,list);     
            
        }
        return new ArrayList<List<String>>(map.values());

    }

在此种解法中学到的,
字符串转字符数组:char [] chars = str.toCharArray();
还有这个方法
map.getOrDefault(key,value);
如果key在map中不存在就,将value获取到
否则就获取map中key对应的值。
相关推荐
数据的世界0122 分钟前
JAVA和C#的语法对比
java·windows·c#
顾安r36 分钟前
11.15 脚本算法 加密网页
服务器·算法·flask·html·同态加密
前端小L1 小时前
图论专题(四):DFS的“回溯”之舞——探寻「所有可能路径」
算法·深度优先·图论
司铭鸿1 小时前
数学图论的艺术:解码最小公倍数图中的连通奥秘
运维·开发语言·算法·游戏·图论
元亓亓亓1 小时前
LeetCode热题100--39. 组合总和
算法·leetcode·职场和发展
2401_841495642 小时前
【LeetCode刷题】找到字符串中所有字母异位词
数据结构·python·算法·leetcode·数组·滑动窗口·找到字符串中所有字母异位词
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——寻找数组的中心下标
算法·leetcode·职场和发展·结构与算法
py有趣2 小时前
LeetCode算法学习之鸡蛋掉落
学习·算法·leetcode
放羊郎2 小时前
机器人自主导航方案概述
人工智能·算法·机器人·slam·建图
冷徹 .2 小时前
Edu144 CD
c++·算法