Pagini recente » Cod sursa (job #1874946) | Cod sursa (job #1883535) | Cod sursa (job #227825) | Cod sursa (job #2726482) | Cod sursa (job #1283143)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("transport.in");
ofstream fout("transport.out");
#define cin fin
#define cout fout
int n, k;
int saltele[16000];
int calcMin() {
int x = saltele[0];
for (int i = 1; i < n; i++) {
if (saltele[i] > x) {
x = saltele[i];
}
}
return x;
}
int calcMax() {
long long int x = saltele[0];
for (int i = 1; i < n; i++) {
x += saltele[i];
}
//if (x > 16000) return 16000;
return x;
}
int main() {
cin >> n >> k;
for (int i = 0; i < n; i++) {
cin >> saltele[i];
}
int minC = calcMin();
int maxC = calcMax();
int el;
while (minC <= maxC) {
int mijloc = (minC + maxC) / 2;
int wagon = 0;
int cap = 0;
bool fail = false;
for (int i = 0; i < n; i++) {
if (cap + saltele[i] <= mijloc) {
cap += saltele[i];
} else {
wagon++;
if (wagon == k) {
fail = true;
break;
}
cap = saltele[i];
}
}
if (fail) {
minC = mijloc + 1;
} else {
maxC = mijloc - 1;
el = mijloc;
}
}
cout << el << '\n';
return 0;
}