原文链接:数据结构005:有效的字母异位词
题目
给定两个字符串
s
和t
,编写一个函数来判断t
是否是s
的字母异位词。注意:若
s
和t
中每个字符出现的次数都相同,则称s
和t
互为字母异位词。示例 1:
输入: s = "anagram", t = "nagaram" 输出: true
示例 2:
输入: s = "rat", t = "car" 输出: false
其中:
1 <= s.length, t.length <= 5 * 104
s
和t
仅包含小写字母
题解
根据题目中对于字母异位词的定义,我们可以知道要判断两个字符串中字符出现的种类和次数是否都相等即可。因此我们可以采用哈希表的方法,提到哈希表我们容易想到使用map,但由于题目中限定s
和 t
仅包含小写字母,所以我们可以使一个一维数组table
来表示每个字母出现次数,而字母减去'a'
作为该字母对应数组的下边索引,例如table['a'-'a']=table[0]
代表字符a代表的在字符串中出现的次数,table['b'-'a']=table[1]
代表字符b代表的在字符串中出现的次数。具体的代码实现如下所示:
class Solution {
public:
bool isAnagram(string s, string t) {
//首先判断一下两个字符串的长度是否相等,如果不相同,则返回false
if(s.size() != t.size()) return false;
vector<int> table(26,0);
for(auto& c : s){
++table[c - 'a'];
}
for(auto& c : t){
if(--table[c - 'a'] < 0)
{
return false;
}
}
return true;
}
};
时间复杂度,空间复杂度,为字符集的大小,此处为a~z
共26个,。
网友评论