Cod sursa(job #1183947)

Utilizator bogdan10bosBogdan Sitaru bogdan10bos Data 10 mai 2014 18:10:25
Problema Transport Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.84 kb
#include <cstdio>
#include <cstdlib>
#include <ctime>
#include <cmath>
#include <cstring>
#include <algorithm>

using namespace std;
int n, i, x, p, u, mij, s, y, l, v[16005];
int fct(int x)
{
    int i, a, s, z;
    a=0;
    s=0;
    z=0;
    for(i=1;i<=n;i++)
    {
        s+=v[i];
        if(s>x)
        {
            a++;
            s=v[i];
        }
    }
    return a+1;
}
int main()
{
    freopen("transport.in", "r", stdin);
    freopen("transport.out", "w", stdout);
    scanf("%d%d", &n, &l);
    for(i=1;i<=n;i++)
    {
        scanf("%d", &v[i]);
        s+=v[i];
    }
    p=1;u=s;
    while(p<=u)
    {
        mij=p+(u-p)/2;
        x=fct(mij);
        if(x<=l)
        {
            y=mij;
            u=mij-1;
        }
        else p=mij+1;
    }
    printf("%d", y);
    return 0;
}