이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
typedef pair<int, int> ii;
typedef vector<pair<int, int>> vii;
typedef vector<int> vi;
typedef long long ll;
#define PB push_back
#define MP make_pair
#define FOR(i, x, y) for (int i = x; i < y ; i ++)
const int MAXN = 21;
ii dp[1 << MAXN]; // num of covered & left over
int main(){
    int n, m;
    cin >> n >> m;
    vi a(n), b(m);
    FOR(i, 0, n){
        cin >> a[i];
    }
    FOR(i, 0, m){
        cin >> b[i];
    }
    sort(a.rbegin(), a.rend());
    dp[0] = MP(0, 0);
    FOR(s, 1, 1 << m){
        dp[s] = MP(0, 0);
        FOR(i, 0, m){
            if ((s & (1 << i))== 0){
                continue;
            }
            int prev = s- (1 << i);
            int indx = dp[prev].first;
            int left = dp[prev].second;
            if (left + b[i] == a[indx]){
                left = 0;
                indx ++;
            }
            else if (b[i] == a[indx]){
                indx ++;
            }
            else{
                left += b[i];
            }
            dp[s] = max(dp[s], MP(indx, left));
        }
        if (dp[s].first == n){
            cout << "YES\n";
            return 0;
        }
        //cout << s << " : " << dp[s].first << ' ' << dp[s].second << '\n';
    }
    cout << "NO\n";
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |