Pagini recente » Cod sursa (job #449795) | Cod sursa (job #2189532) | Cod sursa (job #2416505) | Cod sursa (job #490534) | Cod sursa (job #2278916)
#include <fstream>
using namespace std;
int v[16001]; /// capacitatile saltelelor
int n, maxim, suma, i, k, tr, cap, ramas, st, dr;
ifstream fin ("transport.in");
ofstream fout("transport.out");
int main () {
fin>>n>>k;
for (i=1;i<=n;i++) {
fin>>v[i];
suma += v[i];
if (v[i] > maxim)
maxim = v[i];
}
st = maxim;
dr = suma; /// st si dr sunt capacitati posibile de camion
while (st <= dr) {
cap = (st + dr) / 2;
/// numar cate transporturi fac sa duc totul cu un camion de capacitate cap
tr = 1; /// ramas = cat mai pot incarca in trasportul curent
ramas = cap - v[1]; /// am incarcat prima saltea
for (i=2;i<=n;i++)
if (v[i] <= ramas)
ramas -= v[i];
else {
tr++;
ramas = cap-v[i];
}
if (tr <= k)
dr = cap - 1;
else
st = cap + 1;
}
fout<<st;
return 0;
}