算法升级之路(三)

字母异位词分组

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

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

示例 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对应的值。
相关推荐
ゞ 正在缓冲99%…19 分钟前
leetcode75.颜色分类
java·数据结构·算法·排序
奋进的小暄1 小时前
贪心算法(15)(java)用最小的箭引爆气球
算法·贪心算法
Scc_hy1 小时前
强化学习_Paper_1988_Learning to predict by the methods of temporal differences
人工智能·深度学习·算法
巷北夜未央1 小时前
Python每日一题(14)
开发语言·python·算法
javaisC1 小时前
c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)
c语言·算法·深度优先
爱爬山的老虎1 小时前
【面试经典150题】LeetCode121·买卖股票最佳时机
数据结构·算法·leetcode·面试·职场和发展
SWHL1 小时前
rapidocr 2.x系列正式发布
算法
雾月552 小时前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
想跑步的小弱鸡2 小时前
Leetcode hot 100(day 4)
算法·leetcode·职场和发展
Fantasydg2 小时前
DAY 35 leetcode 202--哈希表.快乐数
算法·leetcode·散列表