Pagini recente » Cod sursa (job #1665089) | Cod sursa (job #1881645) | Cod sursa (job #1791858) | Cod sursa (job #1623684) | Cod sursa (job #482816)
Cod sursa(job #482816)
#include<fstream>
using namespace std;
#define oo 1<<30
ifstream f("transport.in");
ofstream g("transport.out");
long stiva[16001];
long rez,N,K;
int good(int cap)
{ int i=1,j=0,s,k;
while(i<=N && j<=K)
{ for(s=0,k=i;k<=N;k++)
{ s+=stiva[k];
if(s>cap) break;
}
i=k;
j++;
}
if(j<=K)
return 1;
return 0;
}
void search(int left,int right)
{ if(left>right)
return;
int mid=(left+right)>>1;
if(good(mid))
{ rez=mid;
search(left,mid-1);
}
else
search(mid+1,right);
}
int main()
{ int i,maxim=-oo;
f>>N>>K;
for(i=1;i<=N;i++)
{ f>>stiva[i];
stiva[0]+=stiva[i];
if(maxim<stiva[i]) maxim=stiva[i];
}
search(maxim,stiva[0]);
g<<rez;
f.close();
g.close();
return 0;
}