2.字母异位词分组

1.题目描述

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。字母异位词指的是由相同字母组成但排列顺序不同的字符串,例如 "eat""tea"

示例 1:

输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]

输出:[["bat"],["nat","tan"],["ate","eat","tea"]]

解释:

  • 在 strs 中没有字符串可以通过重新排列来形成 "bat"
  • 字符串 "nat""tan" 是字母异位词,因为它们可以重新排列以形成彼此。
  • 字符串 "ate""eat""tea" 是字母异位词,因为它们可以重新排列以形成彼此。

2.解题思路

可以这么理解哈希表的结构,但并非这样

3.代码

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
#include <unordered_map>
#include <algorithm>

using namespace std;

class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        unordered_map<string, vector<string>> mp;

        // 遍历 strs
        for (int i = 0; i < strs.size(); ++i) {
            string str = strs[i];
            string key = str;
            sort(key.begin(), key.end());
            mp[key].push_back(str);
        }

        vector<vector<string>> ans;

        // 遍历 mp
        for (auto it = mp.begin(); it != mp.end(); ++it) {
            ans.push_back(it->second);
        }

        return ans;
    }
};

int main() {
    // 示例输入
    vector<string> strs = {"eat", "tea", "tan", "ate", "nat", "bat"};

    // 创建 Solution 对象并调用函数
    Solution sol;
    vector<vector<string>> result = sol.groupAnagrams(strs);

    // 打印结果
    cout << "[";
    for (int i = 0; i < result.size(); ++i) {
        cout << "[";
        for (int j = 0; j < result[i].size(); ++j) {
            cout << "\"" << result[i][j] << "\"";
            if (j != result[i].size() - 1) {
                cout << ",";
            }
        }
        cout << "]";
        if (i != result.size() - 1) {
            cout << ",";
        }
    }
    cout << "]" << endl;

    return 0;
}

4.代码解析

cpp 复制代码
for (int i = 0; i < strs.size(); ++i) {
            string str = strs[i];
            string key = str;
            sort(key.begin(), key.end());
            mp[key].push_back(str);
        }

遍历strs,如先遍历eat,然后排序为aet,以aet为key将原来的str也就是eat作为value。依次遍历完整个strs。

复制代码
   vector<vector<string>> ans;

        // 遍历 mp
        for (auto it = mp.begin(); it != mp.end(); ++it) {
            ans.push_back(it->second);
        }

遍历每一个key,从aet开始遍历,将对应的所有value加入到ans中

相关推荐
SuperByteMaster1 小时前
keil 工程 .gitignore配置文件
c语言
Merlos_wind2 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
老花眼猫5 小时前
编制椭圆旋转绘图函数
c语言·经验分享·青少年编程·课程设计
智者知已应修善业5 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
云泽8087 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
AI进化营-智能译站8 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust8 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
晨曦夜月8 小时前
map与unordered_map区别
算法·哈希算法
Morwit8 小时前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展