力扣:242.有效的字母异位词
题目:
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。
注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。
解析:
每一个字母都对应一个ASCLL码。可将字母转换成ASCLL码,因此字母也可以作为下标。
第一个字符串中的字母填入:即将其对应索引对应的值+1
第二个字符串中的字母的填入:即将其对应索引对应的值-1
最后检查数组中元素是否都为0
class Solution {
public:
bool isAnagram(string s, string t) {
int record[26] = {0};
for(int i = 0; i < s.size(); i++){
record[s[i]-'a']++;
}
for(int i = 0; i < t.size(); i++){
record[t[i]-'a']--;
}
for(int i = 0; i < 26; i++){
if( record[i] ) return false;
}
return true;
}
};