当前位置: 首页 > news >正文

每日一题(LeetCode)----哈希表--有效的字母异位词

每日一题(LeetCode)----哈希表–有效的字母异位词

1.题目(242. 有效的字母异位词)

  • 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。

    注意:若 st 中每个字符出现的次数都相同,则称 st 互为字母异位词。

    示例 1:

    输入: s = "anagram", t = "nagaram"
    输出: true
    

    示例 2:

    输入: s = "rat", t = "car"
    输出: false
    

    提示:

    • 1 <= s.length, t.length <= 5 * 104
    • st 仅包含小写字母

    进阶: 如果输入字符串包含 unicode 字符怎么办?你能否调整你的解法来应对这种情况?

2.解题思路

思路一:哈希表

两个字符串分别遍历一遍,每个串中各个字符出现的次数都存到各自的哈希表(这里用的是unordered_map,键值表示我们遍历到的字符,键值表示当前字符出现的次数),然后通过比较两个哈希表来判断这两个串是否为有效的字母异位词

思路二:排序

t 是 s的异位词等价于「两个字符串排序后相等」。因此我们可以对字符串 s 和 t 分别排序,看排序后的字符串是否相等即可判断。此外,如果 s 和 t 的长度不同,t 必然不是 s 的异位词。

作者:力扣官方题解
链接:https://leetcode.cn/problems/valid-anagram/

3.写出代码

思路一的代码
class Solution {
public:bool isAnagram(string s, string t) {unordered_map<char,int> match1;unordered_map<char,int> match2;for(char i='a';i<='z';i++){match1[i]=0;match2[i]=0;}for(auto ite=s.begin();ite!=s.end();){match1[*ite]++;ite++;}for(auto ite=t.begin();ite!=t.end();){match2[*ite]++;ite++;}for(char i='a';i<='z';i++){if(match1[i]!=match2[i]){return false;}}return true;}
};
思路二的代码
class Solution {
public:bool isAnagram(string s, string t) {if(s.length()!=t.length()){return false;}sort(s.begin(),s.end());sort(t.begin(),t.end());return s==t;}
};
作者:力扣官方题解
链接:https://leetcode.cn/problems/valid-anagram/
http://www.lryc.cn/news/249369.html

相关文章:

  • 【设计模式】行为型模式-第 3 章第 6 讲【中介者模式】
  • Django 通过 Trunc(kind) 和 Extract(lookup_name) 参数进行潜在 SQL 注入 (CVE-2022-34265)
  • Vue3-toRef 和 toRefs 函数
  • STM32---时钟树
  • 【功能测试】软件系统测试报告
  • CentOS一键安装docker脚本
  • PostGIS学习教程八:空间关系
  • ESP32-Web-Server编程- 通过文本框向 Web 提交数据
  • NAT网络地址转换
  • PyTorch模型训练过程内存泄漏问题解决
  • 【matlab程序】matlab利用工具包nctool读取grib2、nc、opendaf、hdf5、hdf4等格式数据
  • pytorch训练模板
  • 代码随想录二刷 |字符串 |反转字符串
  • Rust语言入门教程(九) - 结构体
  • 如何使用Qchan搭建更好保护个人隐私的本地图床并在公网可访问
  • AI伪原创软件-AI伪原创工具下载
  • 【python脚本】获取OneNET数据写入本地文件
  • 5 存储器映射和寄存器
  • 决策树学习
  • 如何在Ubuntu系统上安装Git
  • Leetcode.974 和可被 K 整除的子数组
  • Vue打包错误UnhandledPromiseRejectionWarning: CssSyntaxError
  • 鸿蒙系统扫盲(三):鸿蒙开发用什么语言?
  • linux 中vmalloc实现简述
  • homeassistant 随笔
  • 带大家做一个,易上手的家常炒鸡蛋
  • 芒格传奇落幕!生前最后一次谈论比特币,说了什么?
  • Springboot如何快速生成分页展示以及统计条数
  • 数据结构:图文详解顺序表的各种操作(新增元素,查找元素,删除元素,给指定位置元素赋值)
  • 2023 年 IntelliJ IDEA下载、安装教程,附详细图文