Pagini recente » Cod sursa (job #1884218) | Cod sursa (job #494447) | Cod sursa (job #1336121) | Cod sursa (job #1842372) | Cod sursa (job #2468637)
#include <cstdio>
int a[16001],N,K;
int basta(int cap)
{
int i,transp=1,sc=0;
for(i=1;i<=N;i++)
{
sc+=a[i];
if(sc>cap)
{
sc=a[i];
transp++;
}
if(transp>K)return 0;
}
return 1;
}
int main()
{
FILE *f=fopen("transport.in","r");
fscanf(f,"%d%d",&N,&K);
int i;
for(i=1;i<=N;i++)
fscanf(f,"%d",&a[i]);
int li=1,lf=1000000000,m;
while(li<=lf)
{
m=(li+lf)/2;
if(basta(m))
lf=m-1;
else
li=m+1;
}
f=fopen("transport.out","w");
fprintf(f,"%d",li);
return 0;
}