Cod sursa(job #1965026)

Utilizator tziplea_stefanTiplea Stefan tziplea_stefan Data 13 aprilie 2017 21:36:24
Problema Ghiozdan Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.17 kb
#include <fstream>
#include <algorithm>
#include <cstdio>
#define VAL 75005
#define NR 20005

using namespace std;

int N, G, i, j;
int dp[VAL];
int nr[NR];
int last[VAL], mx;

int main()
{
    freopen("ghiozdan.in", "r", stdin);
    freopen("ghiozdan.out", "w", stdout);
    scanf("%d %d", &N, &G);
    for (i=1; i<=N; i++)
    {
        scanf("%d", &nr[i]);
        dp[nr[i]]=1;
        last[nr[i]]=nr[i];
    }
    sort(nr+1, nr+N+1);
    for (i=N; i>=1; i--)
    {
        for (j=G-nr[i]; j>0; j--)
        {
            if (dp[j]!=0)
            {
                if (dp[j+nr[i]]==0)
                {
                    dp[j+nr[i]]=dp[j]+1;
                    last[j+nr[i]]=nr[i];
                    mx=max(mx, j+nr[i]);
                }
                else
                {
                    if (dp[j+nr[i]]>dp[j]+1)
                    {
                        dp[j+nr[i]]=dp[j]+1;
                        last[j+nr[i]]=nr[i];
                        mx=max(mx, j+nr[i]);
                    }
                }
            }
        }
    }
    printf("%d %d\n", mx, dp[mx]);
    while (mx!=0)
    {
        printf("%d\n", last[mx]);
        mx-=last[mx];
    }
    return 0;
}