Submission #1112960

#TimeUsernameProblemLanguageResultExecution timeMemory
1112960adiyerLongest beautiful sequence (IZhO17_subsequence)C++17
0 / 100
1 ms2552 KiB
// #pragma optimize ("g",on) // #pragma GCC optimize("inline") // #pragma GCC optimize ("Ofast") // #pragma GCC optimize ("unroll-loops") // #pragma GCC optimize ("03") #include <bits/stdc++.h> #define ios ios_base::sync_with_stdio(0); cin.tie(0); #define pb push_back using namespace std; typedef long long ll; const int N = 1e5 + 2; const int M = (1 << 8); ll n, pos; ll a[N], k[N], dp[N]; void sol(){ cin >> n, pos = 1; for(ll i = 1; i <= n; i++) cin >> a[i]; for(ll i = 1; i <= n; i++) cin >> k[i]; for(ll i = 1; i <= n; i++){ dp[i] = 1; for(ll j = 1; j < i; j++) if((__builtin_popcount(a[j] & a[i]) == k[i])) dp[i] = max(dp[i], dp[j] + 1); if(dp[i] > dp[pos]) pos = i; // cout << dp[i] << '\n'; } vector < ll > ans; ans.pb(pos); while(pos > 1){ for(ll i = pos - 1; i >= 1; i--){ if(__builtin_popcountll(a[pos] & a[i]) == k[pos] && dp[pos] == dp[i] + 1){ pos = i; break; } } ans.pb(pos); if(ans.size() == ans[0]) break; } reverse(ans.begin(), ans.end()); cout << ans.size() << '\n'; for(ll x : ans) cout << x << ' '; } signed main(){ ios sol(); // slow(); // stress(); }

Compilation message (stderr)

subsequence.cpp: In function 'void sol()':
subsequence.cpp:44:17: warning: comparison of integer expressions of different signedness: 'std::vector<long long int>::size_type' {aka 'long unsigned int'} and '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} [-Wsign-compare]
   44 |   if(ans.size() == ans[0]) break;
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...