Pagini recente » Cod sursa (job #2674097) | Cod sursa (job #1060537) | Cod sursa (job #35008) | Cod sursa (job #3274837) | Cod sursa (job #2972021)
#include <fstream>
using namespace std;
ifstream fin("transport.in");
ofstream fout("transport.out");
int n, k, v[16001], s, maxim = 0, st, dr, mid, livrari, volum, solutie;
int main()
{
fin >> n >> k;
for (int i = 1; i <= n; i++)
{
fin >> v[i];
s += v[i];
if (v[i] > maxim)
maxim = v[i];
}
st = maxim;
dr = s;
while (st <= dr)
{
volum = 0;
livrari = 1;
mid = (st + dr) / 2;
for (int i = 1; i <= n; i++)
{
volum += v[i];
if (volum > mid)
{
livrari++;
volum = 0;
i--;
}
}
if (livrari > k)
{
st = mid + 1;
}
else
{
solutie = mid;
dr = mid - 1;
}
}
fout << solutie;
}