Pagini recente » Cod sursa (job #1946776) | Cod sursa (job #720745) | Cod sursa (job #21179) | Cod sursa (job #1710996) | Cod sursa (job #1230307)
#include <cstdio>
using namespace std;
int v[16005],n,k;
int verif(int capac)
{
int i, nr=1 ,suma=0 ;
for(i=1;i<=n;i++)
{
if(v[i]>capac)
return 0;
if(suma+v[i]<=capac)
suma+=v[i];
else
{
nr++;
suma=v[i];
}
}
return nr<=k;
}
int main ()
{
int i,j,dev;
freopen("transport.in","r",stdin);
freopen("transport.out","w",stdout);
scanf("%D %D",&n,&k);
for(i=1;i<=n;i++)
scanf("%D",&v[i]);
i=0;
dev=1<<27;
while(dev)
{
if(!verif(i+dev))
i+=dev;
dev/=2;
}
printf("%d\n",i+1);
return 0;
}