Cod sursa(job #2807624)

Utilizator ancaurseinUrsein Anca ancaursein Data 23 noiembrie 2021 23:26:02
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.82 kb
#include <fstream>

using namespace std;

ifstream fin("transport.in");
ofstream fout("transport.out");

int v[16001];

int main()
{
    int n, k, i, st=0, dr=0, mij, nrdrumuri, s, sol;
    fin >> n >> k;
    for (i = 1;i <= n;i++)
    {
        fin >> v[i];
        if (v[i] > st)
            st = v[i];
        dr = dr + v[i];
    }
    while (st <= dr)
    {
        mij = (st + dr) / 2;
        nrdrumuri = 0;
        s = 0;
        for (i = 1;nrdrumuri <= k && i <= n;i++)
        {
            if (v[i] + s > mij)
            {
                nrdrumuri++;
                s = 0;
            }
            s = s + v[i];
        }
        if (nrdrumuri + 1 > k)
            st = mij + 1;
        else 
        {
            sol = mij;
            dr = mij - 1;
        }
    }
    fout << sol;
}