蓝桥杯 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
相关推荐
油泼辣子多加1 分钟前
【风控】行为评分卡(B卡)模型
算法·金融·集成学习
走过冬季3 分钟前
Java常用数据结构底层实现原理及应用场景
java·开发语言·数据结构
XIMCoCo5 分钟前
C++ 实现二叉树的后序遍历与中序遍历构建及层次遍历输出
java·开发语言·c++
会编程的加缪12 分钟前
算法学习——从零实现循环神经网络
rnn·深度学习·学习·算法·序列数据
dd向上1 小时前
Windows 平台 TCP 通信开发指南
c++·windows·网络协议·tcp/ip
0x7CF4 小时前
SetThrowSegvLongjmpSEHFilter错误和myFuncInitialize 崩溃
java·linux·算法
whoarethenext4 小时前
c/c++的opencv高斯模糊
c语言·c++·图像处理·opencv·图像预处理·高斯模糊
victorika5 小时前
Athena 执行引擎:在线服务计算的效率王者
c++
Felven6 小时前
E. Scuza
数据结构·c++·算法
PingdiGuo_guo6 小时前
C++指针(三)
开发语言·c++