Cod sursa(job #1733211)

Utilizator dragos231456Neghina Dragos dragos231456 Data 24 iulie 2016 00:08:41
Problema Transport Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.7 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("transport.in"); ofstream g("transport.out");
int n,k,v[16002],lt=1,rt=256000000,md,mx;
bool verif()
{
    int s=0,p=1;
    for(int j=1;j<=n;++j)
    {
        if(s+v[j]>md)
        {
            s=v[j];
            ++p;
        }
        else s+=v[j];
    }
    if(s>md) ++p;
    cout<<p<<' '<<md<<endl;
    if(p<=k) return 1;
    else return 0;
}
int main()
{
    f>>n>>k;
    for(int i=1;i<=n;++i)
    {
        f>>v[i];
        mx=max(mx,v[i]);
    }
    while(rt-lt!=1)
    {
        md=(rt+lt)/2;
        if(verif()) rt=md;
        else lt=md;
    }
    if(rt<mx) lt=mx+1;
    g<<rt;
    return 0;
}