Cod sursa(job #1906660)

Utilizator AndreiCroitoruAndrei Croitoru AndreiCroitoru Data 6 martie 2017 15:37:46
Problema Transport Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.87 kb
#include <fstream>
using namespace std;
ifstream in("transport.in");
ofstream out("transport.out");
int n,k,v[16002];
int s,mx;
int lol(int a)
{
    int nr=0,x=0;
    for(int i=1;i<=n;i++)
    {
        if(x+v[i]<=a)
            x+=v[i];
        else
        {
            x=v[i];
            nr++;
        }
    }
    nr++;
    return nr;
}
int cautare(int st, int dr)
{
    long mj=st+(dr-st)/2;
    if(lol(mj)>k)
        return cautare(mj+1,dr);
        else
        {
        if(mj==st)
            return mj;
            else
            if(lol(mj-1)>k)
                return mj;
                else
                return cautare(st,mj-1);
        }
    }
int main()
{
    in>>n>>k;
    for(int i=1;i<=n;i++){
        in>>v[i];
        s+=v[i];
        if(v[i]>mx)
            mx=v[i];
    }
    out<<cautare(mx,s);
    return 0;
}