题目:
代码:
#include<bits/stdc++.h>
using namespace std;
long long n,m,a[100000005];
bool jltm(int x){long long sum=0;for(int i=1;i<=n;i++){if(a[i]>x) sum=sum+a[i]-x;}//计算此时锯片高度砍掉的木材if(sum>=m) return 1;else return 0;
}//写一个函数判断此时锯片高度砍掉的木材大于等于Mirko需要的木材吗?
int main(){long long l=0,mid,r;//设最低高度和最高高度以及中间量scanf("%lld %lld",&n,&m);for(int i=1;i<=n;i++){scanf("%lld",&a[i]);r=max(r,a[i]);}//输入以及找树木最高值while(l<r){mid=(l+r+1)/2;if(jltm(mid)) l=mid;else r=mid-1;}//二分锯片高度printf("%lld",l);//输出return 0;
}