QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#756041#9727. Barkley IIIzake#WA 3ms132740kbC++173.3kb2024-11-16 18:49:062024-11-16 18:49:07

Judging History

你现在查看的是最新测评结果

  • [2025-01-13 03:55:43]
  • hack成功,自动添加数据
  • (/hack/1447)
  • [2024-11-16 18:49:07]
  • 评测
  • 测评结果:WA
  • 用时:3ms
  • 内存:132740kb
  • [2024-11-16 18:49:06]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long
#define fast ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
using namespace std;

void solve();


signed main() {
    fast
    int t = 1;
//    cin >> t;
    while (t--) solve();
}

const int N = 1e6 + 10;

using ll = long long;

int n, q;
ll w[N];

ll k;

struct seg{
    int tr[N << 2];

    void pu(int u){
        int &o = tr[u], l = tr[u << 1], r = tr[u << 1 | 1];
        o = l + r;
    }

    void build(int u, int l, int r){
        if(l == r){
            tr[u] = w[l] >> k & 1;
        }
        else{
            int mid = l + r >> 1;
            build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);
            pu(u);
        }
    }

    void change(int u, int p, int k, int L, int R){
        if(L == R){
            tr[u] = k;
            return;
        }
        int mid = L + R >> 1;
        if(p <= mid) change(u << 1, p, k, L, mid);
        else change(u << 1 | 1, p, k, mid + 1, R);
        pu(u);
    }

    void modify(int u, int l, int r, int L, int R){
        if(tr[u] == 0) return;
        if(L == R){
            tr[u] = 0;
            return;
        }
        int mid = L + R >> 1;
        if(l <= mid) modify(u << 1, l, r, L, mid);
        if(r > mid) modify(u << 1 | 1, l, r, mid + 1, R);
        pu(u);
    }

    int query_sum(int u, int l, int r, int L, int R){
        if(l <= L && R <= r){
            return tr[u];
        }
        int mid = L + R >> 1;
        int res = 0;
        if(l <= mid) res += query_sum(u << 1, l, r, L, mid);
        if(r > mid) res += query_sum(u << 1 | 1, l, r, mid + 1, R);
        return res;
    }

    int query(int u, int l, int r, int L, int R){
        if(L == R) return L;
        int mid = L + R >> 1;
        if(tr[u << 1] != mid - L + 1) return query(u << 1, l, r, L, mid);
        return query(u << 1 | 1, l, r, mid + 1, R);
    }
};

const int K = 63;

seg tr[K];

void set_at(int pos, ll x){
    for(k = 0; k < K; k++){
        tr[k].change(1, pos, (int)(x >> k & 1ll), 1, n);
    }
}

ll calc(int l, int r){
    if(l > r) return -1;
    ll res = 0;
    for(k = 0; k < K; k++){
        if(tr[k].query_sum(1, l, r, 1, n) == r - l + 1) res += 1ll << k;
    }
    return res;
}

void solve() {
    cin >> n >> q;
    for(int i = 1; i <= n; i++) cin >> w[i];
    for(k = 0; k < K; k++) tr[k].build(1, 1, n);
    while(q--){
        int op; cin >> op;
        if(op == 1){
            int l, r; ll x; cin >> l >> r >> x;
            for(k = 0; k < K; k++){
                if(x >> k & 1) continue;
                tr[k].modify(1, l, r, 1, n);
            }
        }
        else if(op == 2){
            int s; ll x; cin >> s >> x;
            set_at(s, x);
        }
        else{
            int l, r; cin >> l >> r;
            ll res = calc(l, r);
            if(r - l + 1 == 1){
                cout << res << '\n';
                continue;
            }
            for(k = K - 1; k >= 0; k--){
                if(tr[k].query_sum(1, l, r, 1, n) == r - l){
                    int p = tr[k].query(1, l, r, 1, n);
                    res = max(res, calc(l, p - 1) & calc(p + 1, r));
                    break;
                }
            }
            cout << res << '\n';
        }
    }
}

詳細信息

Test #1:

score: 100
Accepted
time: 3ms
memory: 132740kb

input:

5 9
7 7 7 6 7
3 1 5
2 1 3
3 1 5
3 1 3
1 1 2 3
3 1 3
2 2 8
3 1 3
3 1 2

output:

7
6
7
3
3
8

result:

ok 6 lines

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 132648kb

input:

10 10
6760061359215711796 1568091718842717482 1568091718842717482 1568091718842717482 5232472783634052627 8795942500783873690 1568091718842717482 1568091718842717482 1568091718842717482 1568091718842717482
1 3 5 7587422031989082829
3 6 10
1 7 8 5197616143400216932
2 4 2518604563805514908
2 2 4533959...

output:

1153048052409963530
35184372088832
176025477579040
580969956778186760

result:

wrong answer 1st lines differ - expected: '1568091718842717482', found: '1153048052409963530'