Cod sursa(job #3242189)

Utilizator oliv_1Bostinescu Octavian oliv_1 Data 9 septembrie 2024 19:25:37
Problema Grupuri Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.71 kb
#include <fstream>
#define ll long long
using namespace std;
ll k,n,v[100005],suma=0;
bool check(ll grupuri)
{
    ll sum=0;
    for(int i=1;i<=n;i++)
    sum+=min(grupuri,v[i]);
    if(sum>=grupuri*k)
        return 1;
    return 0;
}
ll cautbin(int n,int k)
{
    ll st=1,dr=suma,mid,sol;
    while(st<=dr)
    {
        mid=(st+dr)/2;
        if(check(mid)==1)
        {
            sol=mid;
            st=mid+1;
        }
        else
            dr=mid-1;

    }
    return sol;
}
int main()
{
    ifstream cin("grupuri.in");
    ofstream cout("grupuri.out");
    cin>>k>>n;
    for(int i=1;i<=n;i++)
{
    cin>>v[i];
    suma+=v[i];
}
        cout<<cautbin(n,k);
    return 0;
}