给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词。
示例 1:
输入: s = "anagram", t = "nagaram" 输出: true
示例 2:
输入: s = "rat", t = "car" 输出: false
说明:
你可以假设字符串只包含小写字母。
思路:
由于只是字母移位,所以字符串中每个字符出现的次数肯定是不变的,那么只需要分别统计2个字符串中字符出现的次数,再判断各个字符出现的次数是否相同,如果都相同,则是移位的,如果有一个以上不同,则不是移位的
static auto x = []() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
return 0;
}();
class Solution {
public:
bool isAnagram(string s, string t) {
if(s.length() != t.length())
return false;
int m1[26] = {0}, m2[26] = {0};
for(int i = 0; i < s.length(); i++){
m1[s[i]-'a']++;
m2[t[i]-'a']++;
}
for(int i = 0; i < 26; i++){
if(m1[i] != m2[i])
return false;
}
return true;
}
};
效率:
99.80%