蓝桥杯 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
相关推荐
玖釉-4 小时前
编辑距离(Edit Distance)——从字符串相似度到动态规划经典模型
算法·leetcode·动态规划
c238564 小时前
c/c++中的二叉树进阶
c语言·c++·算法
晚风吹红霞4 小时前
C++模板进阶:非类型参数、特化、分离编译与优缺点解析
开发语言·c++
吴可可1234 小时前
Win7下C#开发AutoCAD首选版本
算法
不会C语言的男孩4 小时前
C++ Primer 第8章:IO 库
开发语言·c++
Halo_tjn4 小时前
反射与设计模式2
java·开发语言·算法
磊 子4 小时前
C++仿函数以及STL内置仿函数
开发语言·c++
王璐WL5 小时前
【C++进阶】map/multimap 容器详解:从基础使用到底层实现与高频面试题
c++
_日拱一卒5 小时前
LeetCode:46全排列
算法·leetcode·职场和发展
剑挑星河月5 小时前
31.下一个排列
java·算法·leetcode