Cod sursa(job #2156012)

Utilizator Liviu_Ionut_MoantaMoanta Ionut Liviu Liviu_Ionut_Moanta Data 8 martie 2018 13:09:06
Problema Transport Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.67 kb
#include<fstream>
using namespace std;
ifstream fin("transport.in");
ofstream fout("transport.out");
int n,m,i,j,k,q,sum,st,dr,mid,s;
int v[16005];
int main(){
    fin>>n>>k;
    for(i=1;i<=n;i++){
        fin>>v[i];
        sum+=v[i];
    }
    st=1;
    dr=sum+1;
    while(st<=dr){
        q=0;
        mid=(st+dr)/2;
        s=0;
        i=0;
        while(i<=n&&q<=k){
            while(s+v[i+1]<=mid&&i<=n){
                s+=v[i+1];
                i++;
            }
            s=0;
            q++;
        }
        if(q<=k){
            dr=mid-1;
        }
        else{
            st=mid+1;
        }
    }
    fout<<st;
    return 0;
}