Pagini recente » Cod sursa (job #3153300) | Cod sursa (job #1045904) | Cod sursa (job #913951) | Cod sursa (job #2209702) | Cod sursa (job #1949326)
#include<bits/stdc++.h>
using namespace std;
ifstream f("transport.in");
ofstream g("transport.in");
int v[22552],n,suma,maxim,sol,k;
int main()
{
f>>n>>k;
for(int i=1;i<=n;++i)
{
f>>v[i];
suma+=v[i];
maxim=maxim>v[i]?maxim:v[i];
}
int stanga=maxim;
int dreapta=suma;
while(stanga<=dreapta)
{
int mij=stanga+(dreapta-stanga)/2;
int s=0;
int mis=0;
for(int i=1;i<=n;++i)
{
s+=v[i];
if(s==mij)
{
mis++;
s=0;
}
if(s>mij)
{
mis++;
s=v[i];
}
}
if(s>0)
mis++;
if(mis<=k)
{
sol=mij;
dreapta=mij-1;
}
else
stanga=mij+1;
}
g<<sol;
}