Pagini recente » Cod sursa (job #1277268) | Cod sursa (job #1182476) | Cod sursa (job #346360) | Cod sursa (job #492836) | Cod sursa (job #1021528)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in ("transport.in");
ofstream out ("transport.out");
int N, K, C, v[16005];
bool verifica (int c)
{
int s=0, ct=1;
for (int i=0;i<N;++i)
{
if (s+v[i]<=c)
s=s+v[i];
else
{
--i;
s=0;
++ct;
}
}
if (ct<=K)
return true;
return false;
}
int main()
{
in>>N>>K;
int maxim=0, suma=0;
for (int i=0;i<N;++i)
{
in>>v[i];
suma+=v[i];
if (v[i]>maxim)
maxim=v[i];
}
int a=maxim, b=suma;
while (a<=b)
{
int m=(a+b)/2;
if (verifica(m))
{
b=m-1;
}
else
{
a=m+1;
}
}
out<<a;
}