Cod sursa(job #595436)
Utilizator | Data | 12 iunie 2011 17:08:47 | |
---|---|---|---|
Problema | Grupuri | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.52 kb |
#include<stdio.h>
int n,k,x[100010];
bool ver(const long long &g) {
int i;
long long su=0,j=g*k;
for(i=1;i<=n;++i) {
if(x[i]>g)
su+=g;
else
su+=x[i];
if(su>=j)
break;
}
if(su>=j)
return 1;
return 0;
}
int main() {
long long i,pas;
freopen("grupuri.in","r",stdin);
freopen("grupuri.out","w",stdout);
scanf("%d%d",&k,&n);
for(i=1;i<=n;++i)
scanf("%d",&x[i]);
pas=1<<30;
for(i=0;pas!=0;pas>>=1)
if(ver(i+pas))
i+=(long long)pas;
printf("%lld",i);
return 0;
}