蓝桥杯 2024 C++国 B最小字符串

P10910 [蓝桥杯 2024 国 B] 最小字符串

题目描述

给定一个长度为 N N N 且只包含小写字母的字符串 S S S,和 M M M 个小写字母 c 1 , c 2 , ⋯   , c M c_1, c_2, \cdots, c_M c1,c2,⋯,cM。现在你要把 M M M 个小写字母全部插入到字符串 S S S 中,每个小写字母都可以插入到任意位置。

请问能得到的字典序最小的字符串是什么?

输入格式

第一行包含两个整数 N N N 和 M M M。

第二行包含一个长度为 N N N 的字符串 S S S。

第三行包含 M M M 个小写字母 c 1 , c 2 , ⋯   , c M c_1, c_2, \cdots, c_M c1,c2,⋯,cM。

输出格式

输出一个长度为 N + M N + M N+M 的字符串代表答案。

输入输出样例 #1

输入 #1

复制代码
4 3
abbc
cba

输出 #1

复制代码
aabbbcc

输入输出样例 #2

输入 #2

复制代码
7 3
lanqiao
bei

输出 #2

复制代码
beilanqiao

说明/提示

【评测用例规模与约定】

对于 20 % 20\% 20% 的评测用例, M = 1 M = 1 M=1。

对于 100 % 100\% 100% 的评测用例, 1 ≤ N , M ≤ 1 0 5 1 \le N, M \le 10^5 1≤N,M≤105。

核心思路:在遇到更大字符前插入所有更小字符,直接排序b数组,然后挨个比较。这里记得一个细节一定要b[bi]<a[ai],如果是小于等于只对20%

为什么 < 正确:当 b[bi] == a[ai] 时,选择添加原字符 a[ai] 而非插入 b[bi],这样可以让 b[bi] 在后续遇到更大字符时发挥作用,从而获得更小的字典序。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m;
string a,b;
int main(){
    cin>>n>>m>>a>>b;
    sort(b.begin(),b.end());
    string ans="";
    int ai=0,bi=0;
    while(a[ai]||b[bi]){
        if(!a[ai]&&b[bi]){
            cout<<b[bi++];
        }
        else if(a[ai]&&!b[bi]){
            cout<<a[ai++];
        }
        else if(b[bi]<a[ai]){
            cout<<b[bi++];
        }
        else{
            cout<<a[ai++];
        }
    }
    return 0;
}
相关推荐
Thera7777 分钟前
【Linux C++】彻底解决僵尸进程:waitpid(WNOHANG) 与 SA_NOCLDWAIT
linux·服务器·c++
Wei&Yan11 分钟前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
wregjru27 分钟前
【QT】4.QWidget控件(2)
c++
浅念-32 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
小羊不会打字39 分钟前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
Max_uuc1 小时前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
近津薪荼1 小时前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
艾莉丝努力练剑2 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Once_day2 小时前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养