P8800 [蓝桥杯 2022 国 B] 卡牌 【60分·】救急
  • 板块灌水区
  • 楼主min1127
  • 当前回复3
  • 已保存回复3
  • 发布时间2025/2/6 13:16
  • 上次更新2025/2/6 15:47:08
查看原帖
P8800 [蓝桥杯 2022 国 B] 卡牌 【60分·】救急
1345662
min1127楼主2025/2/6 13:16
#include<bits/stdc++.h>
using namespace std;
int n,m,x=10000000,a[2000005],b[2000005];
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++)cin>>a[i];
	for(int i=1;i<=n;i++){
		cin>>b[i];
		x=min(x,b[i]+a[i]);
	}
	int l=0,r=x,mid;
	while(l<=r){
		mid=(l+r)/2;
		long long sum=0;
		for(int i=1;i<=n;i++) if(a[i]<mid)sum+=mid-a[i];
		if(sum>=m)r=mid-1;
		else l=mid+1;
	}
	cout << mid;
	return 0;
}

求调

2025/2/6 13:16
加载中...