码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java字母异位词分组leetcode_49


    49、字母异位词分组

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

    字母异位词 是由重新排列源单词的字母得到的一个新单词,所有源单词中的字母通常恰好只用一次。

    解法一:

    ​ 将所有字符串根据字母排序,因为每种字母的个数都是相同的,那么排序后的字符串就一定是相同的。

    ​ groupingBy 算子计算完以后,返回的是一个 Map,map 的键是每种排序后的字符串,值是聚合的原始字符串,我们只关心值,所以我们最后 new ArrayList<>(map.values())。

    class Solution {
        public List<List<String>> groupAnagrams(String[] strs) {
            return new ArrayList<>(Arrays.stream(strs)
                .collect(Collectors.groupingBy(str -> {
                    char[] chs = str.toCharArray();
                    Arrays.sort(chs);
                    return new String(chs);
                })).values());
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    执行用时:9 ms, 在所有 Java 提交中击败了30.84%的用户

    内存消耗:44.1 MB, 在所有 Java 提交中击败了93.63%的用户

    通过测试用例:117 / 117

    解法二:

    ​ 编码计数,对每个字符串计数得到该字符串的计数数组,对于计数数组相同的字符串,就互为异位词。
    ​ 因为数组类型没有重写 hashcode() 和 equals() 方法,因此不能直接作为 HashMap 的 Key 进行聚合,那么我们就 把这个数组手动编码变成字符串就行了。
    ​ 比如将 [b,a,a,a,b,c] 编码成 a3b2c1,使用编码后的字符串作为 HashMap 的 Key 进行聚合。

    class Solution {
        public List<List<String>> groupAnagrams(String[] strs) {
            return new ArrayList<>(Stream.of(strs)
                .collect(Collectors.groupingBy(str -> {
                    int[] count = new int[26];
                    for(int i = 0;i < str.length();i++){
                        count[str.charAt(i) - 'a']++;
                    }
                    StringBuilder sb = new StringBuilder();
                    for(int i = 0;i < 26;i++){
                        if(count[i] != 0){
                            sb.append('a' + i);
                            sb.append(count[i]);
                        }
                    }
                    return sb.toString();
                })).values());
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    执行用时:15 ms, 在所有 Java 提交中击败了13.48%的用户

    内存消耗:44.5 MB, 在所有 Java 提交中击败了56.42%的用户

    通过测试用例:117 / 117

  • 相关阅读:
    网络请求流程简述
    Linux:按时间批量删除文件(删除N天前文件)
    python-中断time.sleep一种更优雅的办法:event.wait
    Vuex基础?有这篇就够啦
    万字干货_JDK动态代理及其源码解析 拿捏了
    vue页面缓存解决方案
    微服务技术栈SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式(四):消息队列MQ
    Ctrl+Alt+L或Ctrl+Alt+M或Ctrl+Alt+S热键无法启用(华硕天选)与armoury creat冲突
    用C语言实现单链表的基本操作(附有完整代码)
    python opencv识别蓝牌车牌号 之 取出车牌号 (1/3)
  • 原文地址:https://blog.csdn.net/qq_42900213/article/details/126840824
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号