Cod sursa(job #2417056)

Utilizator alex2kamebossPuscasu Alexandru alex2kameboss Data 28 aprilie 2019 19:46:55
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.7 kb
#include <iostream>
#include <cstdio>

using namespace std;

int n,k,a[16005];

bool ok(int val){
    int poz = 0, s = 0, tr = 0;
    while(poz<n && tr<k){
        if(a[poz]>val)
            return 0;
        s = a[poz];
        ++poz;
        while(poz<n && s+a[poz]<=val)
            s+=a[poz++];
        ++tr;
    }
    return poz==n;
}

int main()
{
    freopen("transport.in","r",stdin);
    freopen("transport.out","w",stdout);

    scanf("%d%d", &n,&k);
    for(int i = 0; i < n; ++i)
        scanf("%d", &a[i]);

    int st = 1, dr = 256000000;
    while(st<dr){
        int mij = (st+dr)/2;
        if(ok(mij))
            dr = mij;
        else
            st = mij + 1;
    }

    cout<<st;

    return 0;
}