比赛 |
20160707 |
评测结果 |
AAAAAAAAAA |
题目名称 |
砍树 |
最终得分 |
100 |
用户昵称 |
iortheir |
运行时间 |
1.366 s |
代码语言 |
C++ |
内存使用 |
4.13 MiB |
提交时间 |
2016-07-07 15:45:45 |
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstdlib>
using namespace std;
int n;//n棵树
int m;//木头所需总长度
int A[1000010];
int l;
int r;
inline int flag(int h)//判断是否已经找出h
{
int sum=0;
for(int i=0;i<n;++i)
{
if(A[i]>h)
{
sum+=A[i]-h;
}
if(sum>=m)
{
return true;
}
}
return false;
}
int main()
{
freopen("eko.in","r",stdin);
freopen("eko.out","w",stdout);
cin>>n>>m;
for(int i=0;i<n;++i)
{
cin>>A[i];
}
sort(A,A+n);
l=A[0];
r=A[n-1];
while(l<=r)
{
int mid=(l+r)/2;
if(flag(mid))
{
l=mid+1;
}
else
{
r=mid-1;
}
}
cout<<r;
return 0;
}