【hot100】跟着小王一起刷leetcode -- 49. 字母异位词分组

【【hot100】跟着小王一起刷leetcode -- 49. 字母异位词分组

  • 49. 字母异位词分组
    • 题目解读
    • 解题思路
    • 代码实现
  • 总结

49. 字母异位词分组

题目解读

49. 字母异位词分组
在这里插入图片描述
ok,兄弟们,咱们来看看这道题,很明显哈,这里的关键词是字母异位词,这是啥意思呢?

我们读一下题目,其实就发现很简单,两个词,如果对字母重新排列之后是相同的,那么这俩就是字母异位词,举个例子哈

ate可以排列为eataet也可以重新排列为eat,那么这三个词就是字母异位词。

这个题让我们对给出的词进行分组,互为字母异位词的存放在一起,那咱们来看看咋做吧。

解题思路

看了刚才的题目介绍,想必你已经有了想法,我把这些词的字母按顺序排列下,然后把相同的放在一起不就做完了吗!

确实,这个想法是可行的,然后你采用最简单的插入排序排了一下,然后发现ac了。
在这里插入图片描述
但当你看到时间复杂度的时候,你陷入了沉思
在这里插入图片描述
这。。。。。

来看看咋改良把,很明显哈,咱们的排序肯定是浪费时间的,那考虑下怎么才能在O(n)时间完成排序呢?或则有没有其他方法可以起到和排序一样的作用呢?

很明显,O(n)时间有点困难,那怎么代替排序呢?

现在想想,无非是把这些词的字母按照顺序存放起来,那这些字母本身有没有自带这种用于排序的东西呢?

答案是有的,没错就是ascii

我们可以采用空间换时间的方法,每当遍历一个单词的时候,首先申请26个空间的数组,并且都置为0,然后根据出现的字母对应的数组值执行**+1**操作,遍历所有字母之后转换为字符串作为判断的识别符,你会发现,字母异位词对应的识别符是相同的,这样我们就在O(n)的时间里为互为字母异位词的单词设置了相同的识别符。

那为什么我们会想到这么做呢?

我们一起想想,排序的作用是什么,也就是让互为字母异位词的单词的字母按顺序排列作为识别符,这样相同识别符的就是字母异位词。但是时间复杂度有点高。

然后我们就在想,要是能不需要和其他字母比较,直接把字母放在他该放的位置就好了。

这样时间复杂度就低了,上面的话也就说O(1)的时间把字母放在该放的地方,这个概念有点熟悉呀,这不就是hash吗!

那怎么才能O(1)呢,这时候我们又想起来字母是有ascii码的,这说明可以根据ascii码做一下,于是我们就想到了用数组直接做个表,存储下字母出现的次数,然后最后直接判断识别符是否相同就可以了。

或则换一个思路,字母异位词有一个特性,就是字母出现的频率是相同的,只需要把这个频率记录下来,这个题就做出来了。

代码实现

排序做法

class Solution {
    public String getSort(String word) {
       char[] word_chars=word.toCharArray();
       for(int i=0;i<word_chars.length;i++){
           char tmp=' ';
           for(int j=word_chars.length-1;j>i;j--){
              if(word_chars[j]<word_chars[j-1])
              {
                  tmp=word_chars[j];
                  word_chars[j]=word_chars[j-1];
                  word_chars[j-1]=tmp;
              }
           }
       }

       return new String(word_chars);
    }


    public List<List<String>> groupAnagrams(String[] strs) {
         Map<String,List<String>> map=new HashMap<String,List<String>>();
         for (String str:strs){
            if(!map.containsKey(getSort(str))){
                map.put(getSort(str),new LinkedList<String>());
            } 
            map.get(getSort(str)).add(str);
         }
         return new LinkedList(map.values());
    }
}

hash做法

class Solution {
    public String getSort(String word) {
        char[] chars = new char[27];
        for (int i = 0; i < 26; i++) {
            chars[i] = '0';
        }
        for (int i = 0; i < word.length(); i++) {
            int ascii = word.charAt(i);
            chars[ascii - 97]++;
        }



        return new String(chars);
    }


    public List<List<String>> groupAnagrams(String[] strs) {
        HashMap<String, List<String>> stringListHashMap = new HashMap<>();
        LinkedList<List<String>> lists = new LinkedList<>();
        for (String str : strs) {
            String str_sort = getSort(str);
            if (!stringListHashMap.containsKey(str_sort))
                stringListHashMap.put(str_sort, new LinkedList<String>());
            stringListHashMap.get(str_sort).add(str);
        }

        for (String s : stringListHashMap.keySet()) {
            List<String> strings = stringListHashMap.get(s);
            lists.add(strings);
        }
        return lists;
    }
}

总结

感觉还是要找规律,一想到字母频率的问题,其实这个题就做出来了。在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/411419.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024生物发酵展全面进行-飞翔泵业制造

参展企业介绍 江苏飞翔泵业制造有限公司始建于上世纪八十年代&#xff0c;二00一年根据《公司法》组建江苏飞翔泵业制造有限公司。公司集科研、设计、生产、经营、服务为一体&#xff0c;企业性质为有限责任公司。现为中国石化集团公司物资资源一级网络成员厂&#xff0c;中国石…

备考2025年考研数学(一)真题练习和解析——填空题

今天距离2025年考研预计还有10个月的时间&#xff0c;看起来挺长&#xff0c;但是对于备考2025年考研的同学来说&#xff0c;必须用好每一天。为了帮助大家提升考研数学一的成绩&#xff0c;我收集整理了1987-2024年的考研数学一的真题和解析&#xff0c;并把2015-2024年十年的…

抖店是怎么运营做起来的?抖音小店每天都需要做什么?新手必看!

大家好&#xff0c;我是电商花花。 很多人疑惑开抖音小店之后&#xff0c;选好商品上架之后每天都需要做什么&#xff1f; 不少新手在开了抖音小店之后每天除了选品之后就不知道要做些什么了。 今天给大家分享一下我们每天做抖音小店的工作内容有哪些&#xff0c;如果你是新…

matlab生成模拟的通信信号

matlab中rand函数生成均匀随机分布的随机数&#xff0c;randn生成正态分布的随机数&#xff1b; matlab来模拟一个通信信号&#xff1b; 通信信号通过信道时&#xff0c;研究时认为它会被叠加上服从正态分布的噪声&#xff1b; 先生成随机信号模拟要传输的信号&#xff0c;s…

【一】【SQL】表的增删查改(部分)

表之“增”操作 建表的操作 mysql> create table students(-> id int unsigned primary key auto_increment,-> sn int unsigned unique key,-> name varchar(20) not null,-> qq varchar(32) unique key-> ); Query OK, 0 rows affected (0.03 sec)mysql&g…

试一下newb,还是有错误呀

解题&#xff1a;原式&#xff1d; 2. 在递增的等比数列 ( a n ) (a_n) (an​)中&#xff0c;若 ( a 3 − a 1 5 2 ) (a_3 - a_1 \frac{5}{2}) (a3​−a1​25​), ( a 2 3 ) (a_2 3) (a2​3), 则公比 (q) A. ( 4 3 ) ( \frac{4}{3} ) (34​) B. ( 3 2 ) ( \frac{3}{2} …

创建vue3项目(基础)

首先打开自己的目录文件输入指令cmd 出现命令行工具 输入指令vue create 项目名称 按回车 选择第三个自己配置 根据需求选择 回车 选择自己需要的版本 出现这个 一直按回车大约5下或者6下 创建完毕 结束 感谢观看

Flutter(二):Row、Column 布局

MaterialApp 对于 MaterialApp&#xff0c;组件提供了一些默认的属性&#xff0c;如AppBar、标题、背景颜色等&#xff0c;你可以默认使用它们 import package:flutter/material.dart;void main() {runApp(const App()); }class App extends StatelessWidget {const App({super…

《名作欣赏》期刊投稿方向投稿邮箱

《名作欣赏》杂志是由国家新闻出版总署批准的正规学术期刊。文学是用语言塑造形象反映社会生活的一种语言艺术&#xff0c;是自觉、独立而又面向整个社会的艺术&#xff0c;是文化中极具强烈感染力的重要组成部分&#xff0c;亦是对美的体现。在现代社会&#xff0c;物欲横流&a…

用matlab实现交通分布预测方法——增长系数法

前言 对于我的第一篇文章&#xff1a;Matlab实现交通分布预测方法 —— 增长系数法 | 平均增长率法、底特律法、福莱特法&#xff0c;有不少同学私信我询问关于如何在 matlab 中调用函数、拆分代码以及需要大量调用的问题。于是我便想着把内容做一些优化&#xff0c;放在这篇文…

【MySQL】MySQL从0到0.9 - 持续更新ing

MySQL SQL 基础 DDL 语句 show databases; show tables; desc table_name; # 获取表信息 show create table 表名; // 查询指定表的建表语句 数据类型 char(10) 不满10个会用空格填充&#xff0c;性能好一点 varchar(10) 变长字符串&#xff0c;性能差一点 CREATE TABLE tabl…

nginx设置缓存时间

一、设置缓存时间 当网页数据返回给客户端后&#xff0c;可针对静态网页设置缓存时间&#xff0c;在配置文件内的http段内server段添加location&#xff0c;更改字段expires 1d来实现&#xff1a;避免重复请求&#xff0c;加快访问速度 第一步&#xff1a;修改主配置文件 #修…

[NOIP2011 普及组] 数字反转

AC代码&#xff1a; #include<iostream>using namespace std;int main() {long long n;cin >> n;long long temp n;long long sum 0;while(temp ! 0){int c temp % 10;sum sum * 10 c;temp temp / 10;}printf("%lld",sum);return 0; }

Spring 中 ApplicationContext 和 BeanFactory 的区别有哪些

先看一张类图&#xff1a; 区别&#xff1a; 1&#xff1a;包目录不同&#xff1a; spring-beans.jar 中 org.springframework.beans.factory.BeanFactory spring-context.jar 中 org.springframework.context.ApplicationContext 2&#xff1a;国际化&#xff1a; BeanFacto…

APP被针对攻击了,要怎么解决

随着APP行业的兴起&#xff0c;游戏公司异军突起&#xff0c;不管是在控证还是攻击方面都是属于最复杂的一个场面&#xff0c;游戏APP逐渐成为DDOS流量攻击的“重灾区”。没有提前做好了解就盲目进军游戏APP行业&#xff0c;一旦被攻击就会让公司束手无策。那么&#xff0c;刚上…

Python从入门到精通指南【第101篇—入门到精通】【文末送书-24】

文章目录 Python从入门到精通指南第一步&#xff1a;入门基础1.1 安装Python1.2 Hello World1.3 变量和数据类型1.4 控制流程 第二步&#xff1a;深入学习2.1 函数和模块2.2 列表、元组和字典2.3 文件操作 第三步&#xff1a;高级主题3.1 面向对象编程3.2 异常处理3.3 正则表达…

python_pyecharts绘制漏斗图

python-pyecharts绘制漏斗图 from pyecharts.charts import Funnel from pyecharts import options as opts# 数据 data [("访问", 100), ("咨询", 80), ("订单", 60), ("点击", 40), ("展现", 20)]# 创建漏斗图 funnel …

Qt OpenGL程序在Windows下正常,但在Linux下无显示问题【已解决】

Qt OpenGL程序在Windows下正常&#xff0c;但在Linux下无显示问题【已解决】 引言一、问题描述二、解决方案三、解决过程记录3.1 定位问题3.2 解决问题&#xff0c;深入分析 引言 在Windows上正常运行的OpenGL程序&#xff0c;到Linux下正常编译…但是没有任何显示(只有背景颜…

【数据结构与算法】动态规划法解题20240227

动态规划法 一、什么是动态规划二、动态规划的解题步骤三、509. 斐波那契数1、动规五部曲&#xff1a; 四、70. 爬楼梯1、动规五部曲&#xff1a; 五、746. 使用最小花费爬楼梯1、动规五部曲&#xff1a; 一、什么是动态规划 动态规划&#xff0c;英文&#xff1a;Dynamic Pro…

23年中科院1区算法|长鼻浣熊优化算法COA原理及其利用与改进(Matlab/Python)

文章来源于我的个人公众号&#xff1a;KAU的云实验台&#xff0c;主要更新智能优化算法的原理、应用、改进 CEC2005中的测试 本文 KAU将介绍一个2023年1月发表在中科院1区KBS上的优化算法——长鼻浣熊优化算法(Coati Optimization Algorithm&#xff0c;COA)[1] 该算法由Dehg…