【剑斩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;
    }
};
相关推荐
程序员三藏6 小时前
接口测试及常用接口测试工具总结
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
spcier8 小时前
图论拓扑排序-Kahn 算法
算法·图论
知星小度S8 小时前
动态规划(一)——思想入门
算法·动态规划
ysa0510308 小时前
动态规划-逆向
c++·笔记·算法
燃于AC之乐8 小时前
我的算法修炼之路--7—— 手撕多重背包、贪心+差分,DFS,从数学建模到路径DP
c++·算法·数学建模·深度优先·动态规划(多重背包)·贪心 + 差分
闻缺陷则喜何志丹8 小时前
【BFS 动态规划】P12382 [蓝桥杯 2023 省 Python B] 树上选点|普及+
c++·蓝桥杯·动态规划·宽度优先·洛谷
chinesegf8 小时前
文本嵌入模型的比较(一)
人工智能·算法·机器学习
We་ct9 小时前
LeetCode 6. Z 字形变换:两种解法深度解析与优化
前端·算法·leetcode·typescript
REDcker9 小时前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
福楠10 小时前
C++ STL | map、multimap
c语言·开发语言·数据结构·c++·算法