算法升级之路(三)

字母异位词分组

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

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

示例 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对应的值。
相关推荐
youngerwang21 分钟前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby1 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
caimouse1 小时前
Reactos 第 5 章 进程与线程 — 5.8 Windows 的 APC 机制
c语言·windows
PHP隔壁老王邻居1 小时前
windows菜单搜索栏无法显示历史记录或者无法使用修复方法
windows
手写码匠2 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
道一232 小时前
Windows系统查看端口占用进程的3种实用方法
windows·笔记
半条-咸鱼2 小时前
【INACCESSIBLE_BOOT_DEVICE】安装 Config Tool 后 Windows 蓝屏,最终通过 VMware 虚拟机解决
windows·stm32·vmware·芯片
无限码力2 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly2 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1232 小时前
SolidWorks草图转三维DWG技巧
算法