Cod sursa(job #2795591)

Utilizator Stefan_GhinescuGhinescu Stefan-George Stefan_Ghinescu Data 6 noiembrie 2021 17:28:43
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.88 kb
#include <fstream>
using namespace std;

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

int main()
{
    int n, k, v[16000], st = -1, dr = 0, mij, rez, nrtransp, transpart;
    fin >> n >> k;
    for(int i = 0; i < n; ++i)
    {
        fin >> v[i];
        if(v[i] > st)
        {
            st = v[i];
        }
        dr += v[i];
    }
    while (st <= dr)
    {
        mij = (st + dr) / 2;
        int nrtransp = 1, transpart = 0;
        for (int i = 0; i < n; ++i)
        {
            if(transpart + v[i] > mij)
            {
                ++nrtransp;
                transpart = 0;
            }
            transpart += v[i];
        }
        if(nrtransp <= k)
        {
            rez = mij;
            dr = mij - 1;
        }
        else
        {
            st = mij + 1;
        }
    }
    fout << rez;
    return 0;
}