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;
}
};

浙公网安备 33010602011771号