【剑斩OFFER】算法的暴力美学——面试题 01.02 :判定是否互为字符串重排

一、题目描述

二、算法原理

思路:哈希表统计字符串里每个字符的个数

这道题我使用的是用一个数组来模拟哈希表(原因:效率高,而且每个字符串都是小写字母,所以我们可以创建数组:int arr[ 26 ] 来模拟哈希表),我们先把第一个字符串里面的每个字符的个数都放到这个哈希表中,然后再访问第二数组,对第二个数组:我们用第一个数组里面存储的第一个字符串里面的每个字符出现个数减去第二个数组里每个字符出现的个数,如果数组里面的值都为0,那么这个两个字符串符合题目要求;当然前提是两个字符串的长度是一样的,如果不一样,这个两个字符串是绝对不符合题目要求。

三、代码实现

cpp 复制代码
class Solution {
public:
    bool CheckPermutation(string s1, string s2) {
        if(s1.size() != s2.size()) return false;//两个字符串的长度都不一样,那么直接返回false
        int num[26] = {0};//数组模拟哈希表
        for(auto& e : s1)//把 s1 的每个字符个数都放到这个数组里面
        {
            char ch = e - 'a';
            num[ch]++;
        }
        for(auto& e : s2)//让 s2 的每个字符个数减去 s1 的字符串的每个字符的个数
        {
            char ch = e - 'a';
            num[ch]--;
        }
        for(auto& e : num)//如果数组里面的数据都为 0 ,那么这两个字符串满足题目要求
        {
            if(e != 0) return false;
        }
        return true;
    }
};
相关推荐
良木生香5 分钟前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘
Brilliantwxx5 分钟前
【C++】String的模拟实现(代码实现与坑点讲解)
开发语言·c++·笔记·算法
憨波个15 分钟前
【说话人日志】DOVER:diarization 输出融合算法
人工智能·算法·音频·语音识别·聚类
爱学习的张大16 分钟前
具身智能论文问答(四):pi0
人工智能·算法
楼田莉子18 分钟前
仿Muduo的高并发服务器:Channel模块与Poller模块
linux·服务器·c++·学习·设计模式
zhouwy11319 分钟前
Linux网络编程从入门到精通
linux·c++
迷途之人不知返20 分钟前
deque的简单认识
数据结构·c++
上弦月-编程21 分钟前
指针编程:高效内存管理核心
java·数据结构·算法
罗超驿22 分钟前
双指针算法经典案例:LeetCode 283. 移动零(Java详解)
java·算法·leetcode
人道领域30 分钟前
【数据结构与算法分析】二叉树面试通关手册:遍历图解 · 分类对比 · 代码模板
数据结构·算法·leetcode·深度优先