Pagini recente » Cod sursa (job #1290236) | Cod sursa (job #1239277) | Cod sursa (job #1856477) | Cod sursa (job #1517739) | Cod sursa (job #838489)
Cod sursa(job #838489)
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<vector>
//#define Vmax 50000
int n,a[50005],c[10005],k,Vmax;
unsigned int v[10005];
void generare()
{
int i;
std::scanf("%d",&n);
for(i=1;i<=n;i++)
std::scanf("%d",&v[i]);
std::fclose(stdin);
}
void rezolvare()
{
int i,j;
Vmax=50000;
std::sort(v+1,v+n+1);
if(v[1]==1)
{
c[++k]=1;
return ;
}
for(i=1;i<=n;i++)
{
if(a[v[i]]==0)
{
c[++k]=v[i];
}
for(j=v[i];j<=Vmax;j+=v[i])
a[j+v[i]]=1;
for(j=0;j+v[i]<=Vmax;j++)
if(a[j]==1)
a[j+v[i]]=1;
}
return ;
}
void afisare()
{
int i;
std::printf("%d",k);
std::printf("\n");
for(i=1;i<=k;i++)
{
std::printf("%d",c[i]);
std::printf("\n");
}
std::fclose(stdout);
}
int main()
{
std::freopen("economie.in","r",stdin);
std::freopen("economie.out","w",stdout);
generare();
rezolvare();
afisare();
return 0;
}