Pagini recente » Cod sursa (job #2304492) | Cod sursa (job #306825) | Cod sursa (job #3155155) | Cod sursa (job #235208) | Cod sursa (job #3296142)
//#include <iostream>
#include <fstream>
using namespace std;
ifstream cin("transport.in");
ofstream cout("transport.out");
long long st, ma, dr, mij, n, i
int f(int cap)
{
int in = 0, tr = 1;
for(i = 1; i <= n ; i ++)
{
in += v[i];
if(in > ap)
{
tr ++;
in = v[i];
}
}
return tr;
}
int main()
{
// st = 1; dr = 256000000;
cin >> n >> k;
for(i =1 ; i<= n i ++ )
{
cin >>v[i];
if (v[i] > ma)
ma = v[i];
}
st = ma;
dr = 256000000;
while(st < dr)
{
mij = (st + dr) / 2;
if(f(mij) <= k)
{
dr = mij;
}
else
{
st = mij +1;
}
}
cout << st << endl;
return 0;
}