Pagini recente » Cod sursa (job #1473325) | Cod sursa (job #2253940) | Cod sursa (job #2233866) | Cod sursa (job #1650223) | Cod sursa (job #2068246)
#include <iostream>
#include <fstream>
using namespace std;
long long a[16100],n,i,k,st,dr,s,m,c,mx;
int calc(int p)
{
int k=0;
int s=0;
for(i=1;i<=n;i++)
{
if(s+a[i]>p) k++,s=a[i];
else s+=a[i];
}
return k+1;
}
int main()
{
freopen("transport.in","r",stdin);
freopen("transport.out","w",stdout);
cin>>n>>k;
for(i=1;i<=n;i++) {cin>>a[i];s+=a[i];if(mx<a[i]) mx=a[i];}
st=1;
dr=s;
while(st<=dr)
{
m=(st+dr)/2;
s=calc(m);
if(s>k||m<mx) st=m+1;
else c=m,dr=m-1;
}
cout<<c;
return 0;
}