文章目录
- 前言
- 一、题目
- 1、原题链接
- 2、题目描述
- 二、解题报告
- 1、思路分析
- 2、时间复杂度
- 3、代码详解
前言
本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。
一、题目
1、原题链接
242. 有效的字母异位词
2、题目描述
二、解题报告
1、思路分析
(1)由于s和t字符串中出现的均是小写字母,而小写字母只有26个,所以我们可以为其建立一个哈希表来统计每个字母出现的个数。而这个哈希表由于长度已知,我们直接用数组模拟即可,初始化数组所有元素均为0,表示字母出现个数均为0。
(2)遍历s字符串,统计出s串中所有字母出现的次数到哈希数组中。
(3)遍历t字符串,将每次遍历到的字符在哈希数组中对应的值减去一次。
(4)如果完成(2)(3)步骤之后哈希数组中的值仍然全为0,说明s和t字符串符合题目要求,即为“有效的字母异位词”。
2、时间复杂度
时间复杂度O(n)
3、代码详解
class Solution {
public:
bool isAnagram(string s, string t) {
int a[26] = {0}; //用作哈希表,统计每个字符出现次数
for (int i = 0; i < s.size(); i++) {
a[s[i] - 'a']++;
}
for (int i = 0; i < t.size(); i++) {
a[t[i] - 'a']--;
}
for (int i = 0; i < 26; i++) {
//存在不为0元素说明两字符串中出现相同的字母的个数不同
if (a[i] != 0) {
return false;
}
}
return true;
}
};