242. 有效的字母异位词(C++)

题目

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。

示例 1:

输入: s = "anagram", t = "nagaram"
输出: true

示例 2:

输入: s = "rat", t = "car"
输出: false

说明:

  • 你可以假设字符串只包含小写字母。

分析与题解

重新排序

使用STL内置的sort函数对两个字符串重新进行排序,排序后再判断是否相等。

class Solution {
public:
    bool isAnagram(string s, string t) {
        if(s.size() != t.size())
            return false;
        sort(s.begin(),s.end());
        sort(t.begin(),t.end());
        return s==t;
    }
};

哈希表

如果两字符串是有效的异位词,则字符个数必然相等。先使用无序哈希表unordered_map<char,int>,存储其中一个字符串中的所有字符个数。然后再遍历另一个字符串中的所有字符时,首先判断该字符对应个数是否大于0,大于则减去1,否则则返回false。

不需要考虑第一个字符串某些字符个数冗余的情况,因为两个字符串长度相等,如果存在冗余,必然有其他字符在二次遍历时存在小于等于0的情况,便可以判断false,异常退出。

代码如下:

class Solution {
public:
    bool isAnagram(string s, string t) {
        if(s.size() != t.size())
            return false;
        unordered_map<char, int> res;
        for(auto i:s){
            res[i]+=1;
        }
        for(auto i : t){
            if(res[i]>0)
                res[i]-=1;
            else return false;
        }
        return true;
    }
};
posted @ 2020-09-10 14:19  脱线森林`  阅读(240)  评论(0编辑  收藏  举报