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

前言

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

一、题目

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

相关推荐

  1. 代码随想-哈希表 | 242 有效字母

    2024-01-29 00:38:04       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-29 00:38:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-29 00:38:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-29 00:38:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-29 00:38:04       20 阅读

热门阅读

  1. 事件的学习

    2024-01-29 00:38:04       30 阅读
  2. lc31 下一个排列

    2024-01-29 00:38:04       34 阅读
  3. 动态规划——编辑距离问题

    2024-01-29 00:38:04       29 阅读
  4. STL标准库(五) 算法,伪函数与空间适配器

    2024-01-29 00:38:04       34 阅读
  5. vue.config.js - 工作笔记

    2024-01-29 00:38:04       31 阅读
  6. uniapp微信小程序-前端设计模式学习(下)

    2024-01-29 00:38:04       34 阅读
  7. Python Totp 验证,JWT 验证

    2024-01-29 00:38:04       35 阅读