Cod sursa(job #1126421)

Utilizator raulstoinStoin Raul raulstoin Data 26 februarie 2014 23:15:03
Problema Economie Scor 70
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.68 kb
#include<fstream>
#include<algorithm>

#define NMAX 1005
#define LMAX 50005

using namespace std;

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

int n,v[NMAX],sol[NMAX],k,Q[LMAX],L;
bool use[LMAX];

void ciur(int val)
{
	for(int j=val;j<LMAX;j+=val)
		use[j]=1;
}

int main()
{
	fin>>n;
	for(int i=1;i<=n;i++)
		fin>>v[i];
	sort(v+1,v+n+1);
	for(int i=1;i<=n;i++)
	{
		if(use[v[i]])
			continue;
		L=0;
		Q[++L]=v[i];
		for(int j=1;j<=50000-v[i];j++)
			if(use[j])
				Q[++L]=j+v[i];
		for(int j=1;j<=L;j++)
			if(!use[Q[j]])
				ciur(Q[j]);
		sol[++k]=v[i];
	}
	fout<<k<<'\n';
	for(int i=1;i<=k;i++)
		fout<<sol[i]<<'\n';
	return 0;
}