每日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/C++ 视角快速上手 Go 语言:核心差异与避坑指南
c语言·开发语言·c++·后端·golang
天上的光1 分钟前
算法——概述
算法
水木流年追梦2 分钟前
CodeTop Top 300 热门题目10-验证IP地址
python·网络协议·tcp/ip·算法·leetcode
小白学大数据3 分钟前
Python 3.7 高并发爬虫:接口请求与页面解析并发处理
开发语言·爬虫·python
样例过了就是过了3 分钟前
LeetCode热题100 乘积最大子数组
c++·算法·leetcode·动态规划
我命由我123454 分钟前
Kotlin 开发 - 双冒号操作符(引用顶层函数、引用成员函数、引用构造函数、引用属性、引用类)
android·java·开发语言·kotlin·android studio·android jetpack·android-studio
Jacky-0085 分钟前
Python pywin32 outlook邮箱
开发语言·python·outlook
minji...5 分钟前
Linux 线程同步与互斥(六) 线程安全与重入问题,死锁,线程done
linux·运维·开发语言·数据库·c++·算法·安全
wayz115 分钟前
Day 16 编程实战:PCA主成分分析与技术指标降维
人工智能·算法·机器学习
探序基因6 分钟前
单细胞转录组Seurat去批次-RPCA算法
算法