Cod sursa(job #2924382)

Utilizator ili9ca2007Ilinca Maria Popa ili9ca2007 Data 1 octombrie 2022 12:45:21
Problema Transport Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.99 kb
#include <fstream>

using namespace std;

int s[16001];

int main()
{
    ifstream cin("transport.in");
    ofstream cout("transport.out");
    int st, dr, c, mij, n, k, t, mini, maxi, cmin;
    cin>>n>>k;
    maxi=0;
    mini=0;
    for (int i=1; i<=n; i++)
    {
        cin>>s[i];
        maxi+=s[i];
        mini=max(mini, s[i]);
        ///capacitatea camionului ia valori de la mini (vol max al unei saltele) la maxi (suma vol saltelelor)
    }

    st=mini;
    dr=maxi;
    cmin=maxi+1;
    while (st<=dr)
    {
        mij=(dr+st)/2;
        ///mij este acum capacitatea
        t=1;
        c=0;
        for (int i=1; i<=n; i++)
        {
            if (c+s[i]<=mij)
                c+=s[i];
            else
            {
                t++;
                c=s[i];
            }
        }
        if (t<=k)
        {
            dr=mij-1;
            cmin=mij;
        }
        else
            st=mij+1;
    }
    cout<<cmin;

    return 0;
}