Pagini recente » Cod sursa (job #2109760) | Cod sursa (job #3214139) | Cod sursa (job #1056949) | Cod sursa (job #47010) | Cod sursa (job #2468607)
#include <cstdio>
int a[16001],N,K;
int basta(int cap)
{
int i,transp=1,sc=0;
for(i=1;i<=N;i++)
{
if(sc+a[i]>cap)
{
sc=a[i];
transp++;
}
else sc+=a[i];
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=256000000,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",lf);
return 0;
}