华华给月月准备礼物

华华给月月准备礼物
简单二分

#include<bits/stdc++.h>
#define lc ((o) << 1)
#define rc ((o) << 1 | 1)
using namespace std;
typedef long long ll;
typedef pair<int,int>Pair;
const int N=1e6+5;
const ll mod=1e9+7;
int a[N];
int n,m;

int slove(int x)
{
    int sum=0;
    for(int i=0;i<n;i++)
    {
        sum+=a[i]/x;
        if(sum>=m)
            return 1;
    }
    return 0;
}


int main()
{
    int ans;
    cin>>n>>m;
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    int l=1, r=1e9, mid;
    while(l<=r)
    {
        mid=(l+r)/2;
        if(slove(mid))
        {
            l=mid+1;
            ans=mid;
        }
        else
        {
            r=mid-1;
        }
    }
    cout<<ans<<endl;
}