蓝桥杯 2. 确定字符串是否是另一个的排列

确定字符串是否是另一个的排列

原题目链接

题目描述

实现一个算法来识别一个字符串 str2 是否是另一个字符串 str1 的排列。

排列的解释如下:如果将 str1 的字符拆分开,重新排列后再拼接起来,能够得到 str2,那么就说字符串 str2 是字符串 str1 的排列。(不忽略大小写)

如果 str2str1 的排列,则输出 YES;如果不是,则输出 NO


输入描述

  • 第一行输入字符串 str1
  • 第二行输入字符串 str2
  • 字符串长度均不超过 100。

输出描述

  • 输出一行,如果 str2str1 的排列,输出 YES
  • 如果 str2 不是 str1 的排列,输出 NO

输入输出样例

输入

in 复制代码
acb
bac

输出

out 复制代码
YES

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main() {
    string str1, str2;
    unordered_map<int, int> mp;
    cin >> str1 >> str2;
    for (char a : str1) mp[a]++;
    for (char b : str2) {
        if (mp.find(b) == mp.end() || mp[b] == 0) {
            cout << "NO";
            return 0;
        }
        mp[b]--;
    }
    cout << "YES";
    return 0;
}//by wqs
相关推荐
Andy7 分钟前
C++ list容器基本逻辑结构详解
c++·windows·list
斯内科1 小时前
四胞胎素数:找出‌个位数分别是 1、3、7、9‌,且‌十位及更高位数字完全相同‌的质数,例如 11、13、17、19
算法·质数·素数·四胞胎素数
Hello.Reader1 小时前
算法基础(十二)——主方法:快速求解常见递归式
算法
想唱rap1 小时前
传输层协议TCP
linux·运维·服务器·网络·c++·tcp/ip
香蕉鼠片2 小时前
面试过程中被问懵
面试·职场和发展
小O的算法实验室2 小时前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带662 小时前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水2 小时前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
瑶池酒剑仙2 小时前
C++类和对象完全指南:从封装继承多态到内存布局的面向对象宝典(雨夜论道)
c语言·开发语言·c++·visual studio
影sir2 小时前
不同测试数据下,该如何选择算法
算法·深度优先