#include<iostream>
#include<cstdio>
using namespace std;
const int N=100500;
int n,m;
int a[N];
int l,r;
int c;
bool work(int k)
{
int sum=0,b=1;
for(int i=1;i<=n;i++)
{
if(sum+a[i]>k)
{
b++;
sum=a[i];
}
else if(sum+a[i]==k)
{
b++;
sum=0;
}
else
{
sum+=a[i];
}
}
if(b<=m) return true;
return false;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
r=max(r,r+a[i]+1);
}
l=1;
while(l<=r)
{
int mid=(l+r)>>1;
c=work(mid);
if(c) r=mid-1;
else l=mid+1;
}
printf("%d",l-1);
return 0;
}