結果
問題 | No.1017 Reiwa Sequence |
ユーザー | qLethon |
提出日時 | 2020-04-03 22:24:28 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 114 ms / 2,000 ms |
コード長 | 1,175 bytes |
コンパイル時間 | 2,627 ms |
コンパイル使用メモリ | 204,812 KB |
最終ジャッジ日時 | 2025-01-09 13:12:08 |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 50 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main(){ int n; cin >> n; vector<int64_t> A(n); copy_n(istream_iterator<int64_t>(cin), n, A.begin()); int m = n; const constexpr int k = 20; n = min(n, k); const constexpr int upper = k * 150000; vector<bitset<2 * upper + 1>> DP(n + 1); bitset<2 * upper + 1> zero; zero.set(upper); for (int i = 0; i < n; i++){ DP[i + 1] = (zero << A[i]) | (zero >> A[i]) | (DP[i] << A[i]) | (DP[i] >> A[i]) | DP[i]; } if (!DP[n][upper]){ puts("No"); return 0; } puts("Yes"); for (int i = 0; i < n; i++) DP[i].set(upper); vector<int> ans; int pos = upper; for (int i = n - 1; i >= 0; i--){ if (DP[i][pos + A[i]]){ ans.push_back(-1); pos += A[i]; } else if(DP[i][pos - A[i]]){ ans.push_back(1); pos -= A[i]; } else ans.push_back(0); } reverse(ans.begin(), ans.end()); for (int i = 0; i < n; i++) cout << A[i] * ans[i] << " "; for (int i = n; i < m; i++) cout << 0 << " "; cout << endl; }