Cod sursa(job #2271557)
Utilizator | Data | 28 octombrie 2018 21:01:14 | |
---|---|---|---|
Problema | Grupuri | Scor | 62 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva de probleme | Marime | 0.62 kb |
#include <fstream>
using namespace std;
ifstream fin("grupuri.in");
ofstream fout("grupuri.out");
long long k,n,i,v[100005];
long long s;
int main()
{
fin >> k >> n;
for (i=1; i<=n; i++)
fin >> v[i], s += v[i];
long long st = 1;
long long dr = s/k;
long long sol = 0;
while (st <= dr)
{
long long mid = (st+dr)/2;
sol = mid;
long long val = 0;
for (i=1; i<=n; i++)
val += min(mid, v[i]);
if (val >= mid*k)
st = mid+1;
else
dr = mid-1;
}
fout << sol;
return 0;
}