每日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;
    }
};
相关推荐
We་ct几秒前
LeetCode 242. 有效的字母异位词:解法解析与时空优化全攻略
前端·算法·leetcode·typescript
执着259几秒前
力扣hot100 - 104、二叉树的最大深度
算法·leetcode·职场和发展
_OP_CHEN2 分钟前
【算法基础篇】(五十四)解析错排问题:从信封错位到编程实战,一次性搞懂排列组合中的 “反常识” 难题!
算法·蓝桥杯·c/c++·组合计数·算法竞赛·acm/icpc·错排问题
浅碎时光8073 分钟前
Qt (信号与槽 Widget控件 qrc文件)
开发语言·qt
我要打打代码4 分钟前
C# 各种类库
开发语言·c#
王老师青少年编程5 分钟前
2022信奥赛C++提高组csp-s复赛真题及题解:策略游戏
c++·真题·csp·信奥赛·csp-s·提高组·策略游戏
小辰辰就要混6 分钟前
20、Lambda表达式和Stream
开发语言·python
Vivienne_ChenW7 分钟前
Apollo 配置中心核心用法(实战版)
java·开发语言·分布式·阿里云·产品运营
小乔的编程内容分享站9 分钟前
C语言函数的声明和定义(文章包括当VScode中含多个.c文件且含.h文件如何同时编译
c语言·开发语言·vscode
苦藤新鸡10 分钟前
54 子集
算法·leetcode·动态规划