Submission #1222484

#TimeUsernameProblemLanguageResultExecution timeMemory
1222484lamlamlam은행 (IZhO14_bank)C++20
0 / 100
1096 ms1516 KiB
#include <bits/stdc++.h> using namespace std; #define endl '\n' #define task "sus" const int MN = 21; int n,m,a[MN],b[MN]; bool dp[MN+1][(1<<MN)]; vector<int> v[MN][MN]; signed main() { ios_base::sync_with_stdio(false); cin.tie(NULL); if(fopen(task".inp","r")){ freopen(task".inp","r",stdin); freopen(task".out","w",stdout); } cin >> n >> m; for(int i=0; i<n; i++) cin >> a[i]; for(int i=0; i<m; i++) cin >> b[i]; for(int mask=0; mask<(1<<m); mask++){ int sum = 0; for(int i=0; i<m; i++) sum += (1 & (mask>>i)) * b[i]; for(int i=0; i<n; i++) if(sum==a[i]) { int sus = __builtin_popcount(mask); if(sus>i and sus<=i+m-n) v[i][sus].push_back(mask);//, cerr << i << '!' << mask << ' ' << sus << endl;; } } dp[0][0] = true; for(int i=0; i<n; i++){ for(int mask=0; mask<(1<<m); mask++){ int cnt = __builtin_popcount(mask); if(cnt<i or cnt>i+m-n-1) continue; for(int j=1; j<=m; j++){ if(j+cnt+n-i+1>m) {break;} //cerr << "MASK: " << mask << ' ' << cnt << ' ' << j << ' ' << i+m-n << endl; for(auto x:v[i][j]){ if((x&mask) or !dp[i][mask]) continue; //cerr << i << ' ' << mask << ' ' << x << ' ' << (x&mask) << endl; dp[i+1][(x ^ mask)] = true; } } } } bool sus = 0; for(int mask=0; mask<(1<<m); mask++) if(dp[n][mask]) sus = true; if(sus) cout << "YES"; else cout << "NO"; cerr << "\nTIME: " << clock() << '\n'; }

Compilation message (stderr)

bank.cpp: In function 'int main()':
bank.cpp:15:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   15 |         freopen(task".inp","r",stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~
bank.cpp:16:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   16 |         freopen(task".out","w",stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...