Pagini recente » Cod sursa (job #1136054) | Cod sursa (job #1216238) | Cod sursa (job #972418) | Cod sursa (job #2014819) | Cod sursa (job #2764844)
#include <fstream>
using namespace std;
int n, k;
int a[16001];
void read() {
int i;
ifstream f("transport.in");
f >> n >> k;
for (i = 1; i <= n; i++)
f >> a[i];
f.close();
}
bool ok(int x) {
int i, nr = 0, sum = 0;
for (i = 1; i <= n; i++) {
if (sum + a[i] <= x)
sum += a[i];
else {
nr++;
sum = a[i];
}
}
nr++;
if (nr <= k)
return 1;
return 0;
}
int rez;
void solve() {
int st = 1, dr = 16000 * 16000, mij;
while (st <= dr) {
mij = (st + dr) / 2;
if (ok(mij))
dr = mij - 1;
else st = mij + 1;
}
rez = st;
}
void output() {
ofstream g("transport.out");
g << rez;
g.close();
}
int main() {
read();
solve();
output();
return 0;
}