Cod sursa(job #2803991)

Utilizator test2021Test test test2021 Data 20 noiembrie 2021 18:03:47
Problema Grupuri Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.49 kb
#include <fstream>

using namespace std;
ifstream fin ("grupuri.in");
ofstream fout ("grupuri.out");
int n,k,i;
long long l,r,m,x,sol;

int v[Nmax];
bool sePoate(long long x)
{
    long long s = 0;
    for (i = 1; i <= n; i++) {
        if (v[i] < x)
            s += v[i];
        else
            s += x;
    }
    if (s >= k * x)
        return true;
    return false;
}
int main()
{
    fin>>k>>n;
    for (i=0;i<n;i++)
        fin>>v[i];
    l=0;
    r=100000000000;
     while (l <= r) {
        m = (l + r) / 2;
        if (sePoate(m)) {
            sol = m;
            l = m + 1;
        }
        else
            r = m - 1;
    }
    fout<<sol;
     fin.close();
    fout.close();
    return 0;
}


/*#include <fstream>

using namespace std;

ifstream fin("grupuri.in");
ofstream fout("grupuri.out");

long long k, n, v[100100], i, g, l, r, m, sol;

bool sePoate(long long x)
{
    long long s = 0;
    for (i = 1; i <= n; i++) {
        if (v[i] < x)
            s += v[i];
        else
            s += x;
    }
    if (s >= k * x)
        return true;
    return false;
}

int main()
{
    fin >> k >> n;
    for (i = 1; i <= n; i++)
        fin >> v[i];
    l = 0;
    r = 100000000000;
    while (l <= r) {
        m = (l + r) / 2;
        if (sePoate(m)) {
            sol = m;
            l = m + 1;
        }
        else
            r = m - 1;
    }
    fout << sol;
    fin.close();
    fout.close();
    return 0;
}*/