zoukankan      html  css  js  c++  java
  • 【LeetCode】49. Group Anagrams

    题目:

    Given an array of strings, group anagrams together.

    For example, given: ["eat", "tea", "tan", "ate", "nat", "bat"], Return:

    [
      ["ate", "eat","tea"],
      ["nat","tan"],
      ["bat"]
    ]

    Note:

    1. For the return value, each inner list's elements must follow the lexicographic order.
    2. All inputs will be in lower-case.

    提示:

    这道题要把所有字母组成相同的单词归为一类。因此我们可以把每个字母都进行排序,然后利用一个hash_map保存。即以排序后的结果作为键,map的值可以是一个set,把排序前的结果插入到set当中。由于set的底层实现利用了平衡二叉搜索树,所以插入以后的元素是已经排好序的。这样归类就完成了。

    代码:

    class Solution {
    public:
        vector<vector<string>> groupAnagrams(vector<string>& strs) {
            vector<vector<string>> res;
            if (strs.empty()) {
                return res;
            }
            unordered_map<string, multiset<string>> um;
            for (string str : strs) {
                string tmp = str;
                sort(tmp.begin(), tmp.end());
                um[tmp].insert(str);
            }
            for (auto m : um) {
                vector<string> sol(m.second.begin(), m.second.end());
                res.push_back(sol);
            }
            return res;
        }
    };

    实际上,由于对单词排序时,题目已经限定了单词只可能是26个小写字母组成的,所以我们可以使用计数排序进一步加快算法的速度(排序部分速度从O(nlogn)变为O(n)),代码如下:

    class Solution {
    public:
        vector<vector<string>> groupAnagrams(vector<string>& strs) {
            vector<vector<string>> res;
            if (strs.empty()) {
                return res;
            }
            unordered_map<string, multiset<string>> um;
            for (string str : strs) {
                string tmp = strSort(str);
                um[tmp].insert(str);
            }
            for (auto m : um) {
                vector<string> sol(m.second.begin(), m.second.end());
                res.push_back(sol);
            }
            return res;
        }
        
        string strSort(string s) {
            vector<int> count(26, 0);
            for (int i = 0; i < s.length(); ++i) {
                ++count[s[i] - 'a'];
            }
            string res = "";
            for (int i = 0; i < 26; ++i) {
                while (count[i]--) {
                    res += ('a' + i);
                }
            }
            return res;
        }
    };
  • 相关阅读:
    【Ubuntu 笔记】翻译 32.1 Job Control
    【Class 学习笔记】 浮点数的储存,运算
    【Ubuntu学习笔记】 安装篇-锐捷、scim、root改密码
    【Ubuntu学习笔记】安装篇-网络配置遇到的问题
    MySQL增删改查
    Spring MVC详解
    SSH和SSM对比总结
    hibernate工作原理
    JavaBean与xml互转的方法详解
    spring MVC如何获取session传值到前台
  • 原文地址:https://www.cnblogs.com/jdneo/p/5291304.html
Copyright © 2011-2022 走看看