Pagini recente » Cod sursa (job #1646866) | Cod sursa (job #2951523) | Cod sursa (job #163165) | Cod sursa (job #1811173) | Cod sursa (job #2468661)
#include <cstdio>
int a[16101],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++;
}
}
return transp<=K;
}
int main()
{
FILE *f=fopen("transport.in","r");
fscanf(f,"%d%d",&N,&K);
int i,mx=0;
for(i=1;i<=N;i++)
{
fscanf(f,"%d",&a[i]);
if(a[i]>mx)mx=a[i];
}
int li=mx,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;
}