Cod sursa(job #739805)

Utilizator Athena99Anghel Anca Athena99 Data 23 aprilie 2012 21:59:48
Problema Transport Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.84 kb
#include <stdio.h>

int v[16001];

int main()
{
    int n=0,i=0,start=0,mid=0,stop=0,t=0,k=0,x=0,s=0;
    freopen("transport.in","r",stdin);
    freopen("transport.out","w",stdout);
    scanf("%d%d",&n,&k);
    for (i=0; i<n; ++i)
    {
        scanf("%d",&v[i]);
        stop+=v[i];
        if (v[i]>start)
            start=v[i];
    }
    --start;
    ++stop;
    while(stop-start>1)
    {
        mid=(stop+start)/2;
        x=mid;
        s=0;
        t=1;
        for (i=0; i<n; ++i)
        {
            if (x>v[i])
                x-=v[i];
            else
            {
                ++t;
                x=mid;
            }
            if(t>k)
                break;
        }
        if(t>k)
            start=mid;
        else
            stop=mid;
    }
    printf("%d",stop+1);
    return 0;
}