Cod sursa(job #1729124)

Utilizator Andrei_CotorAndrei Cotor Andrei_Cotor Data 14 iulie 2016 12:02:02
Problema Transport Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.81 kb
#include <fstream>
using namespace std;
ifstream fi("transport.in");
ofstream fo("transport.out");
int n,k,i,st,dr,mij,x,A[16001],sum,maxim;

int trans(int c)
{
    int i=1,s,transp=0;
    while(i<=n)
    {
        s=0;
        while(s+A[i]<=c && i<=n)
        {
            s+=A[i];
            i++;
        }
        transp++;
    }
    return transp;
}

int main()
{
    fi>>n>>k;
    for(i=1; i<=n; i++)
    {
        fi>>A[i];
        if(A[i]>maxim)
            maxim=A[i];
        sum+=A[i];
    }
    st=maxim;
    dr=sum;
    while(st<dr)
    {
        mij=(st+dr)/2;
        x=trans(mij);
        if(x<=k)
        {
            dr=mij;
        }
        else
        {
            st=mij+1;
        }
    }
    fo<<st<<"\n";
    fi.close();
    fo.close();
    return 0;
}