| # | Time | Username | Problem | Language | Result | Execution time | Memory | 
|---|---|---|---|---|---|---|---|
| 92852 | SamAnd | Longest beautiful sequence (IZhO17_subsequence) | C++17 | 322 ms | 2936 KiB | 
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
const int N = 100005;
int bb = 20;
int bc(int x)
{
    int ans = 0;
    for (int i = 0; i < bb; ++i)
    {
        if ((x & (1 << i)))
            ++ans;
    }
    return ans;
}
int n;
int a[N], b[N];
int dp[N];
int p[N];
void solv1()
{
    for (int i = 1; i <= n; ++i)
    {
        dp[i] = 1;
        p[i] = 0;
        for (int j = 1; j < i; ++j)
        {
            int x = a[i] & a[j];
            if (bc(x) == b[i])
            {
                if (dp[j] + 1 > dp[i])
                {
                    dp[i] = dp[j] + 1;
                    p[i] = j;
                }
            }
        }
    }
    int maxi = 0;
    for (int i = 1; i <= n; ++i)
    {
        if (dp[i] > dp[maxi])
        {
            maxi = i;
        }
    }
    vector<int> ans;
    for (int i = maxi; i; i = p[i])
        ans.push_back(i);
    reverse(ans.begin(), ans.end());
    printf("%d\n", ans.size());
    for (int i = 0; i < ans.size(); ++i)
        printf("%d ", ans[i]);
}
int maxp[1 << 9];
void solv2()
{
    for (int i = 1; i <= n; ++i)
    {
        dp[i] = 1;
        p[i] = 0;
        for (int y = 0; y < (1 << bb); ++y)
        {
            int x = a[i] & y;
            if (bc(x) == b[i])
            {
                if (maxp[y])
                {
                    if (dp[maxp[y]] + 1 > dp[i])
                    {
                        dp[i] = dp[maxp[y]] + 1;
                        p[i] = maxp[y];
                    }
                }
            }
        }
        if (dp[i] > dp[maxp[a[i]]])
            maxp[a[i]] = i;
    }
    int maxi = 0;
    for (int i = 1; i <= n; ++i)
    {
        if (dp[i] > dp[maxi])
        {
            maxi = i;
        }
    }
    vector<int> ans;
    for (int i = maxi; i; i = p[i])
        ans.push_back(i);
    reverse(ans.begin(), ans.end());
    printf("%d\n", ans.size());
    for (int i = 0; i < ans.size(); ++i)
        printf("%d ", ans[i]);
}
int main()
{
    //freopen("input2.txt", "r", stdin);
    scanf("%d", &n);
    for (int i = 1; i <= n; ++i)
        scanf("%d", &a[i]);
    for (int i = 1; i <= n; ++i)
        scanf("%d", &b[i]);
    if (n <= 5000)
        solv1();
    else
    {
        bb = 8;
        solv2();
    }
    return 0;
}
Compilation message (stderr)
| # | Verdict | Execution time | Memory | Grader output | 
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output | 
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output | 
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output | 
|---|---|---|---|---|
| Fetching results... | ||||
