Cod sursa(job #2156077)

Utilizator radugheoRadu Mihai Gheorghe radugheo Data 8 martie 2018 14:13:56
Problema Transport Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.77 kb
#include <fstream>

using namespace std;
ifstream fin ("transport.in");
ofstream fout ("transport.out");
int n, k, i, maxim, suma, st, dr, c, cc, tr, v[16001];
int main()
{
    fin >> n >> k;
    maxim = -1;
    for (i=1; i<=n; i++){
        fin >> v[i];
        maxim = max(maxim, v[i]);
        suma+=v[i];
    }
    st = maxim;
    dr = suma;
    while (st <= dr){
        c = (st + dr)/2;
        cc = c - v[1];
        tr = 1;
        for (i=2; i<=n; i++){
            if (cc >= v[i])
                cc-=v[i];
            else {
                tr++;
                cc = c - v[i];
            }
        }
        if (tr > k){
            st = c + 1;
        }
        else {
            dr = c - 1;
        }
    }
    fout << st;
    return 0;
}