文章目录
leetcode49:49. 字母异位词分组
题目描述
给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。
Example
输入:["eat", "tea", "tan", "ate", "nat", "bat"],
输出:[
["ate","eat","tea"],
["nat","tan"],
["bat"]
]
solution idea
vector->sort->map->vector
-
所有
string
变量进行sort
排序 -
将结果保存至
map<string, vector<string>> res_map
-
将
map<string, vector<string>> res_map
copy到vector<vector<string>> res
class Solution {
public:
vector<vector<string>> groupAnagrams(vector<string>& strs) {
vector<vector<string>> res;
map<string, vector<string>> res_map;
for (string s:strs)
{
string tmp_s=s;
sort(tmp_s.begin(),tmp_s.end());
res_map[tmp_s].push_back(s);
}
for(map<string, vector<string>>::iterator it=res_map.begin();it!=res_map.end();it++)
{
res.push_back(it->second);
}
return res;
}
};
c++ 语法
关联容器迭代器
Note: map
迭代器的应用是一个pair
类型,first
成员保存关键字key
,second
成员保存值value
for(map<string, vector<string>>::iterator it=res_map.begin();it!=res_map.end();it++)
{
res.push_back(it->second);
}
参考文献
- c++ prime 第5版
- c++ reference
来源:CSDN
作者:三生石gg
链接:https://blog.csdn.net/qq_41918762/article/details/104339125