???
查看原帖
???
855779
Kuangxirui楼主2024/11/9 14:11
#include<bits/stdc++.h>
using namespace std;
int long long n,m,a[1000001],ans;
bool check(int h){
	int tot=0;
	for(int i=1;i<=n;i++){
	if(a[i]>h){
		tot+=a[i]-h;
	}
}
	return tot>=m;
}
int main(){
	int maxn=-1;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		if(a[i]>maxn)maxn=a[i];
	}
	int l=0,r=maxn;
	while(l<=r){
		int mid=(l+r)/2;
		if(check(mid)){
			ans=mid;
			l=mid+1;
		}
		else{
			r=mid-1;
		}
	}
	cout<<ans;
}
2024/11/9 14:11
加载中...