原题链接:蓝桥杯2022年第十三届决赛真题-卡牌
注意事项:m记得开long long
参考代码:
#include<bits/stdc++.h>
using namespace std;
struct node
{
long long a;
int b;
}x[200005];
bool cmp(node a,node b)
{
if(a.a==b.a)
{
return a.b<b.b;
}
return a.a<b.a;
}
int main()
{
long long n,m;
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>x[i].a;
}
for(int i=1;i<=n;i++)
{
cin>>x[i].b;
}
sort(x+1,x+1+n,cmp);
int minb;
int ans=x[1].a;
minb=x[1].b;
for(long long j=1;j<n;j++)
{
minb=min(minb,x[j].b);
while(x[j].a!=x[j+1].a)
{
if(m>=j&&minb!=0)
{
x[j].a++;
m-=j;
minb--;
ans=x[j].a;
}
else
{
cout<<ans;
return 0;
}
}
}
minb=min(minb,x[n].b);
while(m>=n&&minb!=0)//卡牌数全部一样时,还能直接加一套牌的情况
{
x[n].a++;
m-=n;
minb--;
ans=x[n].a;
}
cout<<ans;
return 0;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复