免费素材网站素材库,图片列表wordpress主题,某某网站建设策划书2000字,宁波网站建设相信荣胜网络文章目录 前言一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 前言 本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记#xff0c;如有侵权#xff0c;立即删除。 一、题目
1、原题链接 242. 有效的字母异位词 2、题目描述 二、解题… 文章目录 前言一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 前言 本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记如有侵权立即删除。 一、题目
1、原题链接 242. 有效的字母异位词 2、题目描述 二、解题报告
1、思路分析
1由于s和t字符串中出现的均是小写字母而小写字母只有26个所以我们可以为其建立一个哈希表来统计每个字母出现的个数。而这个哈希表由于长度已知我们直接用数组模拟即可初始化数组所有元素均为0表示字母出现个数均为0。 2遍历s字符串统计出s串中所有字母出现的次数到哈希数组中。 3遍历t字符串将每次遍历到的字符在哈希数组中对应的值减去一次。 4如果完成23步骤之后哈希数组中的值仍然全为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;}
};