제출 #987852

#제출 시각아이디문제언어결과실행 시간메모리
987852vjudge1은행 (IZhO14_bank)C++17
0 / 100
5 ms2392 KiB
#include<bits/stdc++.h> using namespace std; #define ll long long #define endl "\n" int n, m, a[25], b[25]; int dp[250000]; int t[25]; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cin >> n >> m; memset(dp, -1, sizeof dp); int s = 0; for (int i = 1; i <= n; i++) { cin >> a[i]; t[i] = t[i - 1] + a[i]; } for (int i = 0; i < m; i++) { cin >> b[i]; } dp[0] = 0; for (int mask = 0; mask < (1 << m); mask++) { int sum = 0; for (int j = 0; j < m; j++) { if (mask & (1 << j)) { sum += b[j]; } } // cout << mask << " " << sum << endl; for (int j = 0 ; j < m; j++) { if (!(mask & (1 << j))) { int newmask = mask ^ (1 << j); // cout << "* " << newmask << " " << sum + b[j] << endl; if (sum + b[j] == t[dp[mask] + 1]) { dp[newmask] = dp[mask] + 1; } else dp[newmask] = dp[mask]; } } } // cout << *max_element(dp, dp + (1 << m) + 1); if (*max_element(dp, dp + (1 << m) + 1) == n) cout << "YES"; else cout << "NO"; }

컴파일 시 표준 에러 (stderr) 메시지

bank.cpp: In function 'int main()':
bank.cpp:15:9: warning: unused variable 's' [-Wunused-variable]
   15 |     int s = 0;
      |         ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...