每日OJ题_哈希表②_力扣面试题 01.02. 判定是否互为字符重排

目录

[力扣面试题 01.02. 判定是否互为字符重排](#力扣面试题 01.02. 判定是否互为字符重排)

解析代码


力扣面试题 01.02. 判定是否互为字符重排

面试题 01.02. 判定是否互为字符重排

难度 简单

给定两个由小写字母组成的字符串 s1s2,请编写一个程序,确定其中一个字符串的字符重新排列后,能否变成另一个字符串。

示例 1:

复制代码
输入: s1 = "abc", s2 = "bca"
输出: true 

示例 2:

复制代码
输入: s1 = "abc", s2 = "bad"
输出: false

说明:

  • 0 <= len(s1) <= 100
  • 0 <= len(s2) <= 100
cpp 复制代码
class Solution {
public:
    bool CheckPermutation(string s1, string s2) {

    }
};

解析代码

当两个字符串的长度不相等的时候,是不可能构成互相重排的,直接返回 false。

如果两个字符串能够构成互相重排,那么每个字符串中各个字符 出现的次数 ⼀定是相同的。因此,可以分别统计出这两个字符串中各个字符出现的次数,然后逐个比较是否相等即可。这样的话,就可以选择哈希表来统计字符串中字符出现的次数。

cpp 复制代码
class Solution {
public:
    bool CheckPermutation(string s1, string s2) {
        if(s1.size() != s2.size())
            return false;
        int hash[26] = {0};
        for(auto& e : s1) // s1元素全部进入哈希表
        {
            hash[e - 'a']++;
        }
        for(auto& e : s2) // 判断哈希表中有没有s2元素
        {
            hash[e - 'a']--;
            if(hash[e - 'a'] < 0)
                return false;
        }
        return true;
    }
};
相关推荐
foundbug9992 分钟前
Delta并联机器人正逆解实现
算法·机器人
乾元4 分钟前
从命令行到自动诊断:构建 AI 驱动的故障树与交互式排障机器人引言
运维·开发语言·网络·人工智能·华为·自动化
deng-c-f9 分钟前
C/C++内置库函数(6):C++中类什么时候使用静态变量
开发语言·c++
2301_7890156213 分钟前
C++:模板进阶
c语言·开发语言·汇编·c++
互亿无线明明13 分钟前
在 Go 项目中集成国际短信能力:从接口调试到生产环境的最佳实践
开发语言·windows·git·后端·golang·pycharm·eclipse
职业码农NO.114 分钟前
《算法与数据结构》:最短路径
数据结构·算法
Ayanami_Reii15 分钟前
进阶数据结构Splay应用-维护数列
数据结构·算法·splay·fhq
噔噔噔噔@15 分钟前
详细介绍Python+Pytest+BDD+Playwright,用FSM打造高效测试框架
开发语言·python·pytest
海上彼尚17 分钟前
Go之路 - 5.go的流程控制
开发语言·后端·golang
sg_knight19 分钟前
什么是设计模式?为什么 Python 也需要设计模式
开发语言·python·设计模式