Pagini recente » Cod sursa (job #1262320) | Cod sursa (job #2581450) | Cod sursa (job #3279237) | Cod sursa (job #3004070) | Cod sursa (job #1456118)
#include <fstream>
#include <cmath>
using namespace std;
ifstream fin("transport.in");
ofstream fout("transport.out");
int N,K,A[16002],tot,sum,k=1,tmp,rs,x;
int main(){
fin >> N >> K;
for(int i = 0;i<N;i++){
fin >> A[i];
tot+=A[i];
}
rs = ceil((float)tot/K);
for(int i = 0;i<N;i++){
x+=A[i];
if(x > rs){
if(A[i] > rs) rs = A[i];else
if(ceil((float)(tot-sum)/rs) > K-k){
tmp = 0;
for(int j = i;tmp < x && j<N;j++){
tmp+=A[j];
}
if(rs < tmp){
if(tmp >= x){
rs = x;
k = ceil((float)(sum+A[i])/rs);
x = 0;
}else{
rs = tmp;
k = ceil((float)sum/rs);
x = 0;
i--;
}
}
}else{
k++;
x = A[i];
}
}
sum+=A[i];
}
fout << rs;
return 0;
}