#include<iostream>
#include<iomanip>
#include<algorithm>
using namespace std;
const long long maxn=1e5+5;
long long val[maxn];
long long n,m;
int check(long long mid)
{
long long tmp = 0;
for(int i=0;i<n;i++)
{
tmp += val[i]/mid;
}//判断条件:第i只鸽子可以分出val[i]/x份肉,所用鸽子可以分出tmp份,必须满足tmp>=m
if(tmp>=m) return 1;
return 0;
}
int main()
{
long long left=1,right=0,ans=0,sum=0,mid=0;
cin >> n >> m;
for(int i=0;i<n;i++)
{
cin >> val[i];
sum = sum+val[i];
}//输入每只鸽子的重量,以及重量和
right = sum/m;//对每人所分最多重量mid进行二分查找,易证上界为sum/m
while(left<=right)
{
mid = left+(right-left)/2;
if(check(mid))
{
ans = mid;
left = mid+1;
}//如果满足条件,则取数轴右半轴继续二分,找到更好的解
else right = mid-1;
}//左右与臂mid相等时,即可退出循环得到ans
cout << ans <<endl;
system("pause");
return 0;
}