Cod sursa(job #1290243)

Utilizator tudormaximTudor Maxim tudormaxim Data 10 decembrie 2014 23:31:36
Problema Economie Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.77 kb
#include <iostream>
#include <cstdio>
using namespace std;
const int nmax = 50001;
int n, x, i, j, maxx, nr, a[nmax], b[nmax];
int main()
{
    freopen("economie.in", "r", stdin);
    freopen("economie.out", "w", stdout);
    scanf("%d", &n);
    for(i=1; i<=n; i++)
    {
        scanf("%d", &x);
        if(maxx<x) maxx=x;
        a[x]=1;
    }
    b[0]=1;
    for(i=1; i<=maxx; i++)
        if(a[i]==1)
            for(j=0; j<=maxx-i; j++)
                if(b[j]!=0 && b[j+i]!=1)
                {
                    b[j+i]=1;
                    if (a[i]!=2) a[i]=2, nr++;

                }
    printf("%d\n", nr);
    for(i=1; i<=maxx; i++)
        if(a[i]==2)
            printf("%d ", i);
    fclose(stdin);
    fclose(stdout);
    return 0;
}