每日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;
    }
};
相关推荐
格林威1 分钟前
工业相机图像高速存储(C++版):直接IO存储方法,附海康相机实战代码!
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机
代码雕刻家2 分钟前
3.1.课设实验-Java核心技术-检索简历
java·开发语言
小此方4 分钟前
Re:从零开始的 C++ STL篇(七)二叉搜索树增删查操作系统讲解(含代码)+key/key-value场景联合分析
开发语言·c++
共享家95274 分钟前
Java 入门(IDEA 高效调试 与 数组)
java·开发语言·intellij-idea
火山上的企鹅5 分钟前
Qt/QGroundControl 实战:接入 Skydroid(云卓) G20 遥控器 Android SDK 并实时显示摇杆与信号质量
android·开发语言·qt·qgroundcontrol·云卓sdk
TracyCoder1236 分钟前
LeetCode Hot100(70/100)—— 322. 零钱兑换
算法·leetcode·职场和发展
曾阿伦7 分钟前
Python项目管理从Poetry迁移到uv:极速体验与实操指南
开发语言·python·uv
2401_891482179 分钟前
C++中的观察者模式
开发语言·c++·算法
沐雲小哥12 分钟前
bevfomer算法嵌入的tricks
数码相机·算法
wangzy198212 分钟前
一个高效稳定的多边形三角化算法(支持自交和孤岛检测)
算法·图形渲染