Submission #603299

#TimeUsernameProblemLanguageResultExecution timeMemory
603299izanbfLongest beautiful sequence (IZhO17_subsequence)C++14
0 / 100
41 ms90984 KiB
#include <bits/stdc++.h>
using namespace std;

const int MAXN = 1.01e5;
// dp[prefix][suffix][num] : length of the largest beautiful sequence ending
//                           in a position with left bits equal to <prefix>,
//                           and having <num> common right bits with <suffix>
int dp[1<<10][1<<10][11];
int jp[1<<10][1<<10][11];
int previ[MAXN];
int a[MAXN];
int k[MAXN];

inline int left_bits(int v)  {  return v >> 10;    }
inline int right_bits(int v) {  return v & ((1<<10) - 1);     }
inline int bitcount(int v)   {  return __builtin_popcount(v); }

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);

    int n;
    cin >> n;
    memset(dp, 0, sizeof(dp));
    memset(jp, 0xff, sizeof(jp));
    memset(previ, 0xff, sizeof(previ));

    for (int i = 0; i < n; ++i) cin >> a[i];
    for (int i = 0; i < n; ++i) cin >> k[i];

    int ans = -1;
    int last = -1;

    for (int i = 0; i < n; ++i) {
        int longest = 0;

        for (int pref = 0; pref < (1<<10); ++pref) {
            int common_left = bitcount(pref & left_bits(a[i]));
            int required_common_right = k[i] - common_left;
            if (required_common_right >= 0 and required_common_right <= 10) {
                int length = 1 + dp[pref][right_bits(a[i])][required_common_right];
                if (length > longest) {
                    longest = length;
                    previ[i] = jp[pref][right_bits(a[i])][required_common_right];
                }
            }
        }

        for (int suff = 0; suff < (1<<10); ++suff) {
            int& length = dp[left_bits(a[i])][suff][bitcount(right_bits(a[i]) & suff)];
            if (length < longest) {
                length = longest;
                jp[left_bits(a[i])][suff][bitcount(right_bits(a[i]) & suff)] = i;
            }
        }
        
        if (longest > ans) {
            ans = longest;
            last = i;
        }
    }

    vector<int> seq;
    while (last != -1) {
        seq.push_back(last);
        last = previ[last];
    }
    reverse(seq.begin(), seq.end());

    cout << seq.size() << endl;
    for (int i = 0; i < seq.size(); ++i) {
        if (i > 0) cout << ' ';
        cout << 1+seq[i];
    }
    cout << endl;
}

Compilation message (stderr)

subsequence.cpp: In function 'int main()':
subsequence.cpp:71:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   71 |     for (int i = 0; i < seq.size(); ++i) {
      |                     ~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...