Pagini recente » Cod sursa (job #303316) | Cod sursa (job #847813) | Cod sursa (job #2437008) | Cod sursa (job #2428169) | Cod sursa (job #1350134)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("transport.in");
ofstream out("transport.out");
int main()
{
int n,k,s=0,v[16000],maxx=0,i,in,mij,sf,m,cont,r;
in>>n>>k;
for(i=1;i<=n;i++)
{
in>>v[i];
s=s+v[i];
if(maxx<v[i])
maxx=v[i];
}
in=maxx;
sf=s;
while(in<=sf)
{
mij=(in+sf)/2;
m=0;
cont=1;
for(i=1;i<=n;i++)
{
m=m+v[i];
if(m>mij)
{
m=v[i];
cont++;
}
}
if(cont<=k)
{sf=mij-1;
r=mij;}
else
{in=mij+1;
r=mij+1;}
}
out<<r;
return 0;
}