Submission #1133546

#TimeUsernameProblemLanguageResultExecution timeMemory
1133546JelalTkmLongest beautiful sequence (IZhO17_subsequence)C++20
23 / 100
15 ms1860 KiB
#include <bits/stdc++.h> #pragma GCC optimize ("O3") #pragma GCC target ("sse4") using namespace std; #define int long long int const int N = 3e5 + 10; const int md = 1e9 + 7; const int INF = 1e18; int32_t main(int32_t argc, char *argv[]) { ios::sync_with_stdio(false); cin.tie(nullptr); int T = 1; // cin >> T; while (T--) { int n; cin >> n; vector<int> a(n), k(n); for (int i = 0; i < n; i++) cin >> a[i]; for (int i = 0; i < n; i++) cin >> k[i]; if (n <= 5000) { vector<int> dp(n + 1); for (int i = 1; i < n; i++) { for (int j = i - 1; j >= 0; j--) { int an = (a[i] & a[j]); int cnt = __builtin_popcountll(an); // cout << a[i] << " " << a[j] << " " << an << " " << cnt << " " << (cnt == k[i]) << '\n'; if (cnt == k[i]) { dp[i] = max(dp[i], dp[j] + 1); } } } int ans = 0, ind; for (int i = 0; i < n; i++) if (dp[i] > ans) ans = dp[i], ind = i; if (ans != 0) { cout << ans + 1 << '\n'; vector<int> asq; int i = ind; while (true) { bool ok = 0; asq.push_back(i + 1); for (int j = i - 1; j >= 0; j--) { int an = (a[i] & a[j]); int cnt = __builtin_popcountll(an); if (dp[i] == dp[j] + 1 && cnt == k[i]) { i = j; ok = 1; break; } } if (!ok) break; } reverse(asq.begin(), asq.end()); for (auto i : asq) cout << i << " "; cout << '\n'; } else { cout << 1 << '\n' << 1 << '\n'; } } } return 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...