Pagini recente » Cod sursa (job #1269605) | Cod sursa (job #1638184) | Cod sursa (job #893680) | Cod sursa (job #361612) | Cod sursa (job #1007463)
#include <iostream>
#include <fstream>
#define nmax 16001
using namespace std;
ifstream in("transport.in");
ofstream out("transport.out");
int n,k,maxim=0,hi,lo,i,num,mid,vol,middle;
int v[nmax];
bool ok;
int main(){
in >> n >> k;
for (i=1; i<=n; i++){
in >> v[i];
lo=max(v[i], lo);
hi+=v[i];
}
while (hi-lo>1){
mid=(hi+lo)/2;
num=0;
vol=0;
for (i=n; i>0; i--){
ok=true;
if (vol<mid && vol+v[i]<=mid) vol+=v[i];
else num++, vol=v[i];
if (i==1) num++;
}
if (num<=k) hi=mid, maxim=mid;
else lo=mid;
}
out << maxim;
return 0;
}