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中

相关推荐
BestOrNothing_20151 分钟前
Ubuntu 22.04 下使用 VS Code 搭建 ROS 2 Humble 集成开发环境
c++·vscode·python·ros2·ubuntu22.04
2301_776508724 分钟前
分布式系统监控工具
开发语言·c++·算法
Irissgwe5 分钟前
Linux进程信号
linux·服务器·开发语言·c++·linux进程信号
暮冬-  Gentle°6 分钟前
C++与区块链智能合约
开发语言·c++·算法
Oueii8 分钟前
C++中的代理模式实现
开发语言·c++·算法
艾莉丝努力练剑10 分钟前
【Linux:文件 + 进程】理解IPC通信
linux·运维·服务器·开发语言·网络·c++·ide
山上三树14 分钟前
C++ 回调函数(Callback Function)详解
开发语言·c++
sonnet-102917 分钟前
拓扑排序的实现
java·c语言·开发语言·笔记·算法
hz_zhangrl19 分钟前
CCF-GESP 等级考试 2026年3月认证C++二级真题解析
c++·gesp·c++二级·gesp2026年3月·gesp c++二级
学嵌入式的小杨同学20 分钟前
STM32 进阶封神之路(二十四):低功耗实战全攻略 —— 电池供电传感器节点(RTC 唤醒 + DHT11 采集 + 功耗优化)
c++·stm32·单片机·嵌入式硬件·mcu·架构·硬件架构