Cod sursa(job #613216)

Utilizator teban.mihaiTeban Mihai Andrei teban.mihai Data 18 septembrie 2011 16:33:33
Problema Transport Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.88 kb
#include <fstream>

using namespace std;

ifstream f("transport.in");
ofstream g("transport.out");

int i,n,k, a[16001],maxi, suma,sol;

bool verific(int x){
    int t=0,i=1,suma;
    if x<maxi return false;
    while i<=n{
        suma=0;
        while (i<=n && suma+a[i]<=x){
            suma+=a[i];
            i++;
        }
        t++;
    }
    if t<=k return true;
        else return false;
}

int caut_binar(int st,int dr){
    int mid=(st+dr)/2;
    while st<=dr{
        if (verific(mid-1)==true) dr=mid-1;
            else if (verific(mid)==true) return mid;
                else st=mid+1;
        mid=(st+dr)/2;
    }
}

int main(){
    f >> n >> k;
    for (i=1; i<=n; i++){
        f >> a[i];
        maxi=max(maxi,a[i]);
        suma+=a[i];
    }
    sol=caut_binar(maxi,suma);
    g << sol;
    f.close();
    g.close();
    return 0;
}