Pagini recente » Cod sursa (job #432726) | Cod sursa (job #1083552) | Cod sursa (job #1517769) | Cod sursa (job #142289) | Cod sursa (job #1880451)
#include <bits/stdc++.h>
using namespace std;
int main()
{
int v[16005]={0}, n, k, s, max, m, st, dr, gr, gr2;
ifstream f("transport.in");
ofstream g("transport.out");
f >> n >> k;
for(int i=1;i<=n;++i){
f>>v[i];
s += v[i];
if(v[i]>max) max=v[i];
}
st=max; dr=s;
while(st!=dr){
m = (st+dr)/2;
gr = 0;
gr2 = 0;
for(int i=1;i<=n;++i)
{
gr += v[i];
if (gr>m){
gr = v[i];
++gr2;
}
}
if (gr2>=k) st=m+1; else dr=m;
}
g << st <<"\n";
}