Cod sursa(job #2405489)

Utilizator 12222Fendt 1000 Vario 12222 Data 14 aprilie 2019 16:08:20
Problema Zebughil Scor 90
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.85 kb
#include <bits/stdc++.h>

using namespace std;

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

int n,g;
int dp[(1<<18)],a[18];

int main()
{
    int t=3;

    while(t--)
    {
        fin>>n>>g;

        for(int i=0;i<n;i++)
            fin>>a[i];

        long long sum;
        for(int stare=1;stare<(1<<n);stare++)
        {
            sum=0;
            for(int bit=0;bit<n;bit++)
                if(stare & (1<<bit))sum+=a[bit];

            if(sum<=g)dp[stare]=1;
            else {

                dp[stare]=n+1;
                for(int n_stare=((stare - 1) & stare); n_stare>0; n_stare=((n_stare - 1) & stare))
                    dp[stare]=min(dp[stare],dp[n_stare]+dp[stare-n_stare]);
            }
        }

        fout<<dp[(1<<n)-1]<<"\n";
    }

    fin.close();
    fout.close();

    return 0;
}