求助 ARC A
  • 板块学术版
  • 楼主Double_Light
  • 当前回复3
  • 已保存回复4
  • 发布时间2025/1/26 22:07
  • 上次更新2025/1/27 12:31:55
查看原帖
求助 ARC A
761137
Double_Light楼主2025/1/26 22:07

思路与官方题解完全相同,但是 WA*7

#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
string s,t;
string ans;
int a[1000005];
int main(){
	cin>>n>>m>>s>>t;
	s=" "+s;t=" "+t;
	int x=t[m];
	for(int i=1;i<=m;i++)a[i]=t[i];
	sort(a+1,a+m+1);
	int p=m;
	int f=1,f2=1;
	for(int i=1;i<=n;i++){
		if(p==0)break;
		if(a[p]==s[i])f=0;
		if(s[i]<a[p]){
			s[i]=a[p],p--,f2=0;
		}
	}
	if(a[p+1]>x||p==m)s[n]=x;
	if(!f&&f2&&s[n]<x)s[n]=x;
	for(int i=1;i<=n;i++)cout<<s[i];
	return 0;
}
/*
10 10
3354444432
9915555534
*/
2025/1/26 22:07
加载中...