Pagini recente » Cod sursa (job #2481026) | Cod sursa (job #865859) | Cod sursa (job #2915721) | Cod sursa (job #683309) | Cod sursa (job #1453267)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("transport.in");
ofstream g("transport.out")
int N,t[100],s,K;
int div(int low,int high){
cout<<low<<" "<<high<<endl;
int mid,nr,q;
if(low==high)
return low;
mid=(high+low)/2;
q=0;nr=1;
for(int i=0;i<N;i++){
q+=t[i];
if(q+t[i+1]>=mid){
nr++;
q=0;
}
}
if(nr>K)
return div(mid+1,high);
else
return div(low,mid-1);
}
int main()
{
f>>N>>K;
s=0;
for(int i=0;i<N;i++){
f>>t[i];
s+=t[i];
}
g<<div(s/K,s);
return 0;
}