Pagini recente » Cod sursa (job #370015) | Cod sursa (job #2497933) | Cod sursa (job #806657) | Cod sursa (job #2619353) | Cod sursa (job #2832716)
#include <fstream>
using namespace std;
ifstream in("transport.in");
ofstream out("transport.out");
int volume[16005],k,n;
bool incape(int dimensiune,int volume[])
{
int s=0;
int nrtransp=0;
for(int i=1;i<=n;i++)
{
if(s+volume[i]<=dimensiune)
s+=volume[i];
else
{
nrtransp++;
s=volume[i];
}
}
nrtransp++;///pt ultimul transport
if(nrtransp<=k)
return true;
return false;
}
int cautbin(int st,int dr)
{
int rasp=-1;
while(st<=dr)
{
int mij=(st+dr)/2;
if(incape(mij,volume)==true)
{
rasp=mij;
dr=mij-1;
}
else
st=mij+1;
}
return rasp;
}
int main()
{
int svol=0;
in>>n>>k;
for(int i=1;i<=n;i++)
{
in>>volume[i];
svol+=volume[i];
}
out<<cautbin(1,svol);
return 0;
}