Cod sursa(job #1937329)
| Utilizator | Data | 23 martie 2017 21:23:55 | |
|---|---|---|---|
| Problema | Economie | Scor | 0 |
| Compilator | cpp | Status | done |
| Runda | Arhiva de probleme | Marime | 0.6 kb |
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("economie.in");
ofstream fout("economie.out");
int v[1010],d[50010],sol[1010];
int n,i,j,k;
int main ()
{
fin >> n;
for (i=1; i<=n; i++)
fin >> v[i];
sort (v+1, v+n+1);
d[0] = 1;
for (i=1; i<=n; i++)
if (d[v[i]] == 0)
{
sol[++k] = v[i];
for (j=0; j+v[i]<=v[n]; j+=v[i])
if (d[j] == 1)
d[j+v[i]] = 1;
}
fout << k << "\n";
for (i=1; i<=k; i++)
fout << sol[i] << "\n";
return 0;
}
