답안 #679266

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
679266 2023-01-08T00:49:49 Z Hacv16 은행 (IZhO14_bank) C++17
52 / 100
69 ms 628 KB
#include<bits/stdc++.h>
using namespace std;

const int MAX = 21;
const int MAXM = 2005;
const int INF = 0x3f3f3f3f;

int n, m, a[MAX], b[MAX], sums[1 << MAX];
bool dp[MAX][1 << MAX], dp2[MAXM];

int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);

    cin >> n >> m;

    for(int i = 1; i <= n; i++) cin >> a[i];
    for(int i = 0; i < m; i++) cin >> b[i];

    if(n == 1){
        dp2[0] = true;

        for(int i = 1; i <= n; i++)
            for(int j = MAXM - 1; j >= 0; j--)
                if(j >= b[i]) dp2[j] |= dp2[j - b[i]];

        cout << (dp2[a[1]] ? "YES" : "NO") << '\n';

        exit(0);
    }

    for(int mask = 0; mask < (1 << m); mask++){
        int cur = 0;

        for(int i = 0; i < m; i++)
            if(mask & (1 << i)) cur += b[i];

        sums[mask] = cur;
    }

    dp[0][0] = true;

    for(int i = 1; i <= n; i++){
        for(int mask = 0; mask < (1 << m); mask++){
            for(int sub = mask; sub > 0; sub = (sub - 1) & mask)
                dp[i][mask] |= (dp[i - 1][mask ^ sub] && sums[sub] == a[i]);
        }
    }

    bool pos = false;

    for(int mask = 0; mask < (1 << m); mask++)
        pos |= dp[n][mask];

    cout << (pos ? "YES" : "NO") << '\n';

    exit(0);
}
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 212 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 340 KB Output is correct
2 Correct 1 ms 340 KB Output is correct
3 Correct 1 ms 340 KB Output is correct
4 Correct 1 ms 340 KB Output is correct
5 Correct 1 ms 340 KB Output is correct
6 Correct 1 ms 340 KB Output is correct
7 Correct 1 ms 340 KB Output is correct
8 Correct 1 ms 340 KB Output is correct
9 Correct 1 ms 340 KB Output is correct
10 Correct 1 ms 340 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 468 KB Output is correct
2 Correct 19 ms 444 KB Output is correct
3 Correct 49 ms 604 KB Output is correct
4 Correct 69 ms 592 KB Output is correct
5 Correct 50 ms 608 KB Output is correct
6 Correct 25 ms 488 KB Output is correct
7 Correct 20 ms 496 KB Output is correct
8 Correct 15 ms 468 KB Output is correct
9 Correct 44 ms 588 KB Output is correct
10 Correct 45 ms 524 KB Output is correct
11 Correct 68 ms 628 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 0 ms 212 KB Output isn't correct
2 Halted 0 ms 0 KB -