【代码随想录】LC 242. 有效的字母异位词

文章目录

  • 前言
  • 一、题目
    • 1、原题链接
    • 2、题目描述
  • 二、解题报告
    • 1、思路分析
    • 2、时间复杂度
    • 3、代码详解

前言

本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。

一、题目

1、原题链接

242. 有效的字母异位词

2、题目描述

【代码随想录】LC 242. 有效的字母异位词_第1张图片

二、解题报告

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;
    }
};

你可能感兴趣的:(代码随想录,c语言,c++,java,python,算法,数据结构,散列表)