算法升级之路(三)

字母异位词分组

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

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

示例 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对应的值。
相关推荐
艾莉丝努力练剑1 小时前
【C语言16天强化训练】从基础入门到进阶:Day 11
c语言·学习·算法
暴走十八步1 小时前
配置windows下apache+PHP环境
windows·php·apache
Pafey2 小时前
【Deepseek】Windows MFC/Win32 常用核心 API 汇总
c++·windows·mfc
浩少7023 小时前
LeetCode-22day:多维动态规划
算法·leetcode·动态规划
岁月静好20253 小时前
Leetcode 深度优先搜索 (15)
算法·leetcode·深度优先
离越词4 小时前
C++day1作业
数据结构·c++·算法
凤年徐4 小时前
【数据结构与算法】LeetCode 20.有效的括号
c语言·数据结构·算法·leetcode
医工交叉实验工坊5 小时前
R 语言 ComplexUpset 包实战:替代 Venn 图的高级集合可视化方案
算法·r语言
东皇太星6 小时前
模运算(密码学/数论/算法)
数据结构·算法·密码学
一水鉴天7 小时前
整体设计 修订 之1 三“先”之“基” 与范畴重构:康德先验哲学的批判性程序化实现
java·人工智能·算法