Cod sursa(job #1512678)

Utilizator LizaSzabo Liza Liza Data 28 octombrie 2015 14:51:33
Problema Transport Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.61 kb
#include <fstream>
#define nmax 16005
using namespace std;
ifstream f1("transport.in");
ofstream f2("transport.out");
int s[nmax],i,n,k;
void cit(){
f1>>n>>k;
for(i=1;i<=n;i++){
    f1>>s[i];
}
}
int check(int x){
    int sum=0,c=0;
    for(i=1;i<=n;i++){
        sum+=s[i];
        if(sum>x){c++; sum=s[i];}
    }
    c++;
    return c<=k;

}
int main(){
    int l,r,sol,mid;
    cit();
    l=0;
    r=nmax*nmax;
    while(l<=r){
        mid=(l+r)/2;
        if(check(mid)){
            sol=mid;
            r=mid-1;
        }
        else{l=mid+1;}
    }
    f2<<sol<<"\n";

}