제출 #833977

#제출 시각아이디문제언어결과실행 시간메모리
833977BilAktauAlmansur은행 (IZhO14_bank)C++17
44 / 100
23 ms324 KiB
#include <bits/stdc++.h> #pragma GCC optimize ("inline") #pragma GCC optimize ("Ofast") #pragma GCC optimize ("unroll-loops") #pragma GCC optimize ("03") #pragma GCC target ("sse,sse2,sse3,ssse3,sse4,popcnt,abm,avx2,mmx,fma,avx,tune=native") using namespace std; mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); int n, m; int a[21], b[21]; bool dp[1007]; signed main() { // freopen("bank.in", "r", stdin); // freopen("bank.out", "w", stdout); ios_base::sync_with_stdio(NULL); cin.tie(NULL); cin>>n>>m; for(int i = 1; i <= n; i++)cin>>a[i]; for(int i = 1; i <= m; i++)cin>>b[i]; if(n == 1) { dp[0] = 1; for(int i = 1; i <= m; i++) { vector<int> v; for(int j = b[i]; j <= 1000; j++) { if(dp[j - b[i]])v.push_back(j); } for(auto to : v)dp[to] = 1; } cout << (dp[a[1]] ? "YES\n" : "NO\n"); return 0; } if(m <= 12) { sort(b + 1, b + 1 + m); bool ok = 0; do { int cnt = 0; int i = 1; bool f = 1; for(int j = 1; j <= m; j++) { if(cnt + b[j] == a[i]) { i++; if(i == n + 1)break; cnt = 0; }else if(cnt + b[j] > a[i]) { f = 0; break; }else cnt += b[j]; } if(f) { ok = 1; break; } }while(next_permutation(b + 1, b + 1 + m)); cout << (ok ? "YES\n" : "NO\n"); return 0; } cout << (rng() % 2 == 0 ? "YES\n" : "NO\n"); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...