Pagini recente » Cod sursa (job #815187) | Cod sursa (job #2650309) | Cod sursa (job #1646901) | Cod sursa (job #815208) | Cod sursa (job #1646888)
#include <fstream>
using namespace std;
int n,k;
ifstream fin("transport.in");
ofstream fout("transport.out");
int a[16005];
int nrtrans(int x)
{
int c=1,s1=0;
for(int i=1;i<=n;i++)
{
if((a[i]+s1)<=x)
s1+=a[i];
else
{
c++;
s1=a[i];
}
}
return c;
}
void rez()
{
int d;
int Left=1,Right=256000,mid,sol;
while(Left<=Right)
{
mid=(Left+Right)/2;
d=nrtrans(mid);
if(d<=k)
{
sol=mid;
Right=mid-1;
}
else if(d>k) Left=mid+1;
}
fout<<sol;
}
int main()
{
fin>>n>>k;
for(int i=1;i<=n;i++)
fin>>a[i];
rez();
}