Cod sursa(job #2509661)

Utilizator victorzarzuZarzu Victor victorzarzu Data 14 decembrie 2019 14:52:19
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda roadtooni Marime 1.02 kb
#include <bits/stdc++.h>

using namespace std;
ifstream f("transport.in");
ofstream g("transport.out");
int n,k;
int maxim = -INFINITY,s,maximt;
int a[16000];
void Citire()
{
    f>>n>>k;
    for(int i=1;i<=n;++i)
    {
        f>>a[i];
        if(a[i] > maxim) maxim = a[i];
        s += a[i];
    }
    f.close();
}

void Rezolvare()
{
    int st = maxim; //minimul posibil este volumul maxim
    int dr = s; //maximul posibil este suma volumelor
    while(st<=dr)
    {
        int mij = (st+dr)/2;
        int nr = 1;
        s = 0;
        for(int i=1;i<=n;++i)
        {
            if(s + a[i] <= mij) s += a[i];
            else
            {
                ++nr;
                s = a[i];
            }
        }
        if(nr > k)
            st = mij + 1;
        else
        {
            maximt = mij;
            dr = mij - 1;
        }
    }
}

void Afisare()
{
    g<<maximt;
    g.close();
}

int main()
{
    Citire();
    Rezolvare();
    Afisare();
    return 0;
}