Cod sursa(job #316295)

Utilizator drag0s93Mandu Dragos drag0s93 Data 18 mai 2009 23:44:05
Problema Grupuri Scor 64
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.62 kb
#include<cstdio>

using namespace std;

#define IN "grupuri.in","r",stdin
#define OUT "grupuri.out","w",stdout

int N , K ;
int A[100020];
bool ok = false;
int verifica(int x)
{
	int sum = 0;
	for(int i =  1 ; i <= N ; ++i)
		if(A[i] > x)	sum += x;
		else sum += A[i];
	if(sum >= x * K)	return 1;
	else return 0;
}
int main()
{
	freopen(IN);
	freopen(OUT);
	scanf("%d%d",&K,&N);
	for(int i = 1 ; i <= N ; ++i) scanf("%d",&A[i]);	
	int st = 0 , dr = 200000000 , m;
	while(st <= dr)
	{
		m = (st + dr) / 2;
		if(verifica(m) == 1)	st = m + 1;
		else dr = m - 1;
	}
	printf("%d\n",dr);
	return 0;
}