力扣每日一题49:字母异位词分组

题目描述:

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

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

示例 1:

复制代码
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

示例 2:

复制代码
输入: strs = [""]
输出: [[""]]

示例 3:

复制代码
输入: strs = ["a"]
输出: [["a"]]

提示:

  • 1 <= strs.length <= 104
  • 0 <= strs[i].length <= 100
  • strs[i] 仅包含小写字母

通过次数

542.1K

提交次数

799.9K

通过率

67.8%

思路和题解:

字母异位词里面的的字母都是相同的,只是排列顺序不同,如果我们把每个单词都排序一遍,排序后字母异位词是相等的,然后再将字符串数组排序一边,此时字母异位词就挨在一起了,我们只要把连在一起并且排序后相等的两个字母放进一个组合里,最后把所有的组合返回即可。听不懂的话我举个例子,就拿样例一来说strs=["eat","tea","tan","ate","nat","bat"],把每个单词排序得到a=[aet, aet ,ant ,aet ,ant ,abt],再将字符串数组a排序,排序的时候连带strs一起交换得到strs=[bat tea ate eat nat tan] a=[abt aet aet aet ant ant] ,即

复制代码
第一次将每个单词排序
strs=[eat tea tan ate nat bat] 
   a=[aet aet ant aet ant abt] 
第二次将a中单词作为一个整体排序
strs=[bat tea ate eat nat tan] 
   a=[abt aet aet aet ant ant] 

来看我的代码:

cpp 复制代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        vector<vector<string>> ans;
        vector<string> a;
        int n=strs.size();
        for(int i=0;i<n;i++)
        {//先对原始字符串数组中每一个字符串进行排序
            a.push_back(strs[i]);
            sort(a[i].begin(),a[i].end());
        }
        // //test1
        // for(int i=0;i<n;i++)
        //     cout<<strs[i]<<" ";
        // cout<<endl;
        // for(int i=0;i<n;i++)
        //     cout<<a[i]<<" ";
        // cout<<endl;
        // 再对字符串数组a排序,strs跟着换
        for(int i=0;i<n-1;i++)
        {
            int k=i;
            for(int j=i+1;j<n;j++)
            {
                if(a[j]<a[k]) k=j;
            }
            string temp=a[i];
            a[i]=a[k],a[k]=temp;
            temp=strs[i],strs[i]=strs[k],strs[k]=temp;
        }
        // //test2
        // for(int i=0;i<n;i++)
        //     cout<<strs[i]<<" ";
        // cout<<endl;
        // for(int i=0;i<n;i++)
        //     cout<<a[i]<<" ";
        // cout<<endl;

        //这个时候字母异位词就黏在一起了
        int pos=0,i=0;
        while(pos<n)
        {
            vector<string> group;
            group.emplace_back(strs[pos]);
            while(pos<n-1&&a[pos]==a[pos+1])
            {
                pos++;
                group.emplace_back(strs[pos]);
            }
            pos++;
            ans.emplace_back(group);
        }
        return ans;
    }
};

改进:

上述方法的核心是将所有的字母异位词放在一起(指位置相邻),然后再将相邻且排序后相等的字符串放在一个字符串数组里。其实将排序后的一个string作为键,对应的排序之前的string作为值放入一个map里,我们就可以直接把所有的字母异位词放在一起(不仅仅是字母异位词不是相邻,而且非字母异位词之前也分开了)。看代码:

cpp 复制代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        vector<vector<string>> ans;
        map<string,vector<string>> mp;
        int n=strs.size();
        for(int i=0;i<n;i++)
        {
            string key=strs[i];
            sort(key.begin(),key.end());
            mp[key].emplace_back(strs[i]);
        }
        for(auto it=mp.begin();it!=mp.end();it++)
        {
            ans.emplace_back(it->second);
        }
        return ans;
    }
};

运行:

相关推荐
qq_340474029 分钟前
6.1 python加载win32或者C#的dll的方法
java·python·c#
梁下轻语的秋缘19 分钟前
每日c/c++题 备战蓝桥杯(小球反弹)[运动分解求解,最大公约数gcd]
c语言·c++·学习·算法·数学建模·蓝桥杯
SiMmming22 分钟前
【算法竞赛】状态压缩型背包问题经典应用(蓝桥杯2019A4分糖果)
c++·经验分享·算法·职场和发展·蓝桥杯·动态规划
审计侠23 分钟前
Apache Struts2 漏洞(CVE-2017-5638)技术分析
java·struts·web安全·apache·安全性测试
DexterYttt32 分钟前
AT_abc212_d [ABC212D] Querying Multiset
数据结构·c++·算法·优先队列
前往深圳42 分钟前
数据结构:LinkedList与链表
java·开发语言·学习
刻意思考42 分钟前
KM算法的时间复杂度,为什么可以降低一个数量级
后端·算法·程序员
橙序员小站44 分钟前
探究分布式哈希算法:哈希取模与一致性哈希
算法·架构
敲键盘的小夜猫1 小时前
Java服务端性能优化:从理论到实践的全面指南
java·开发语言·性能优化
飞川0011 小时前
【LeetCode 热题100】45:跳跃游戏 II(详细解析)(Go语言版)
算法·go