Pagini recente » Cod sursa (job #2956085) | Cod sursa (job #2978664)
#include <fstream>
using namespace std;
ifstream cin ("transport.in");
ofstream cout ("transport.out");
int v[16001];
int main()
{
int n,k,i,cmin=0,cmax=0,sol=16000;
cin >> n >> k;
for (i=1;i<=n;i++) {
cin >> v[i];
if (v[i]>cmin)
cmin=v[i];
cmax=cmax+v[i];
}
while(cmin<=cmax)
{
int cmid=(cmin+cmax)/2,kc=1,cc=0;
for (i=1;i<=n;i++)
if (cc+v[i]<=cmid)
cc+=v[i];
else {
kc++;
cc=v[i];
}
if (kc<=k) {
sol=cmid;
cmax=cmid-1;
}
else
cmin=cmid+1;
}
cout << sol;
return 0;
}