QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#389024#4405. 普罗霍洛夫卡bachbeo2007100 ✓4910ms41628kbC++204.7kb2024-04-13 23:45:032024-04-13 23:45:03

Judging History

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

  • [2024-04-13 23:45:03]
  • 评测
  • 测评结果:100
  • 用时:4910ms
  • 内存:41628kb
  • [2024-04-13 23:45:03]
  • 提交

answer

// Judges with GCC >= 12 only needs Ofast
// #pragma GCC optimize("O3,no-stack-protector,fast-math,unroll-loops,tree-vectorize")
// MLE optimization
// #pragma GCC optimize("conserve-stack")
// Old judges
// #pragma GCC target("sse4.2,popcnt,lzcnt,abm,mmx,fma,bmi,bmi2")
// New judges. Test with assert(__builtin_cpu_supports("avx2"));
// #pragma GCC target("avx2,popcnt,lzcnt,abm,bmi,bmi2,fma,tune=native")
// Atcoder
// #pragma GCC target("avx2,popcnt,lzcnt,abm,bmi,bmi2,fma")
/*
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds;
typedef tree<int,null_type,less<int>,rb_tree_tag,tree_order_statistics_node_update> ordered_set;
- insert(x),erase(x)
- find_by_order(k): return iterator to the k-th smallest element
- order_of_key(x): the number of elements that are strictly smaller
*/
#include<bits/stdc++.h>
using namespace std;
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
uniform_real_distribution<> pp(0.0,1.0);
#define ld long double
#define pii pair<int,int>
#define piii pair<int,pii>
#define mpp make_pair
#define fi first
#define se second
const int mod=998244353;
const int maxn=400005;
const int B=256;
const int maxs=260;
const int maxm=200005;
const int maxq=1000005;
const int maxl=25;
const int maxa=1000000;
const int root=3;
const int base=101;

int f(int x,int a){
    return (x-(a&(x-1)))&(x-1);
}
int g(int x,int a){
    return (a&(x-1));
}

int a[maxn],c[2][maxn];
struct Block{
    int L,R;
    int total[2],add=0;
    int cnt[B+5],num[2][B+5],pos[B+5],cc[2][B+5],dd[B+5];
    void build(int k=1){
        for(int t=0;t<=1;t++){
            //for(int x=1;x<B;x<<=1) for(int i=L;i<=R;i++) c[t][i]^=num[t][x+f(x,a[i])];
            for(int i=B/4;i>=1;i>>=1) for(int j=0;j<i;j++) num[t][i+j]^=((num[t][i*2+j]^num[t][i*3+j])>>1);
            for(int i=1;i<=B/4;i<<=1) for(int j=0;j<i;j++){
                num[t][i*2+j]^=num[t][i+j];
                num[t][i*3+j]^=num[t][i+j];
            }
        }
        for(int i=L;i<=R;i++){
            for(int t=0;t<=1;t++) c[t][i]^=cc[t][g(B,a[i])]^num[t][B/2+g(B/2,a[i])];
            a[i]+=add;
        }
        add=0;
        memset(num,0,sizeof(num));
        memset(cc,0,sizeof(cc));
        memset(dd,0,sizeof(dd));
        memset(pos,0,sizeof(pos));
        if(k) init();
    }
    void init(){
        memset(cnt,0,sizeof(cnt));
        for(int i=L;i<=R;i++){
            pos[g(B,a[i])]=i;
            dd[g(B,a[i])]^=1;
            cnt[B/2+f(B/2,a[i])]^=B/2;
        }
        for(int i=B/4;i>=1;i>>=1) for(int j=0;j<i;j++) cnt[i+j]^=((cnt[i*2+j]^cnt[i*3+j])>>1);
        for(int i=1;i<=B/4;i<<=1) for(int j=0;j<i;j++){
            cnt[i*2+j]^=cnt[i+j];
            cnt[i*3+j]^=cnt[i+j];
        }
    }
    int query(int t,int l,int r){
        l=max(l,L);r=min(r,R);
        if(l>r) return 0;
        if(l==L && r==R) return total[t];
        else{
            build();
            int res=0;
            for(int i=l;i<=r;i++) res^=c[t][i];
            return res;
        }
    };
    void update(int t,int l,int r){
        l=max(l,L);r=min(r,R);
        if(l>r) return;
        //cout << "update " << L << ' ' << R << ' ' << l << ' ' << r << '\n';
        if(l==L && r==R){
            add++;
            total[t]^=cnt[B/2+g(B/2,add)];
            num[t][B/2+f(B/2,add)]^=(B/2);
            /*
            for(int x=1;x<B;x<<=1){
                num[t][x+g(x,add)]^=x;
            }
            */
            int id=pos[f(B,add)];
            //cout << '*' << id << '\n';
            if(id) cc[t][f(B,add)]^=(((a[id]+add)^(a[id]+add-1))/B)*B;
            if(dd[f(B,add)]) total[t]^=(((a[id]+add)^(a[id]+add-1))/B)*B;
        }
        else{
            build(0);
            for(int i=l;i<=r;i++){
                a[i]++;
                total[t]^=(a[i]^(a[i]-1));
                c[t][i]^=(a[i]^(a[i]-1));
            }
            init();
        }
    }
}S[maxn/B+5];

int n,m,d[maxn],lst[maxn];
int res[maxn];
vector<pii> qq[maxn];

void solve(){
    cin >> n >> m;
    for(int i=1;i<=n;i++) cin >> d[i];
    for(int i=1;i<=m;i++){
        int l,r;cin >> l >> r;
        qq[r].push_back({l,i});
    }
    for(int i=0;i<=n/B;i++){
        S[i].L=max(1,i*B);
        S[i].R=min(i*B+B-1,n);
        S[i].init();
    }
    for(int i=1;i<=n;i++){
        for(int j=(lst[d[i]]+1)/B;j<=i/B;j++) S[j].update(i&1,lst[d[i]]+1,i);
        lst[d[i]]=i;
        for(auto [l,id]:qq[i]) for(int j=l/B;j<=i/B;j++) res[id]^=S[j].query(i&1,l,i);
    }
    for(int i=1;i<=m;i++) cout << res[i] << '\n';
}

signed main(){
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);cout.tie(NULL);
    int test=1;//cin >> test;
    while(test--) solve();
}

Details

Subtask #1:

score: 5
Accepted

Test #1:

score: 5
Accepted
time: 2ms
memory: 22116kb

Test #2:

score: 0
Accepted
time: 0ms
memory: 20160kb

Test #3:

score: 0
Accepted
time: 0ms
memory: 20072kb

Test #4:

score: 0
Accepted
time: 0ms
memory: 20160kb

Test #5:

score: 0
Accepted
time: 0ms
memory: 18044kb

Subtask #2:

score: 5
Accepted

Dependency #1:

100%
Accepted

Test #6:

score: 5
Accepted
time: 23ms
memory: 20492kb

Test #7:

score: 0
Accepted
time: 22ms
memory: 18392kb

Test #8:

score: 0
Accepted
time: 27ms
memory: 20356kb

Test #9:

score: 0
Accepted
time: 27ms
memory: 20496kb

Test #10:

score: 0
Accepted
time: 23ms
memory: 18392kb

Subtask #3:

score: 10
Accepted

Dependency #2:

100%
Accepted

Test #11:

score: 10
Accepted
time: 669ms
memory: 25696kb

Test #12:

score: 0
Accepted
time: 674ms
memory: 25524kb

Test #13:

score: 0
Accepted
time: 673ms
memory: 25660kb

Test #14:

score: 0
Accepted
time: 668ms
memory: 25708kb

Test #15:

score: 0
Accepted
time: 669ms
memory: 27040kb

Subtask #4:

score: 10
Accepted

Dependency #3:

100%
Accepted

Test #16:

score: 10
Accepted
time: 1720ms
memory: 29852kb

Test #17:

score: 0
Accepted
time: 1721ms
memory: 29860kb

Test #18:

score: 0
Accepted
time: 1717ms
memory: 31616kb

Test #19:

score: 0
Accepted
time: 1710ms
memory: 31464kb

Test #20:

score: 0
Accepted
time: 1723ms
memory: 31708kb

Subtask #5:

score: 10
Accepted

Dependency #4:

100%
Accepted

Test #21:

score: 10
Accepted
time: 3124ms
memory: 35612kb

Test #22:

score: 0
Accepted
time: 3100ms
memory: 36768kb

Test #23:

score: 0
Accepted
time: 3101ms
memory: 36688kb

Test #24:

score: 0
Accepted
time: 3117ms
memory: 37292kb

Test #25:

score: 0
Accepted
time: 3129ms
memory: 35816kb

Subtask #6:

score: 10
Accepted

Dependency #5:

100%
Accepted

Test #26:

score: 10
Accepted
time: 3968ms
memory: 38684kb

Test #27:

score: 0
Accepted
time: 3954ms
memory: 38688kb

Test #28:

score: 0
Accepted
time: 3943ms
memory: 38748kb

Test #29:

score: 0
Accepted
time: 3938ms
memory: 38572kb

Test #30:

score: 0
Accepted
time: 3945ms
memory: 40040kb

Subtask #7:

score: 10
Accepted

Test #31:

score: 10
Accepted
time: 791ms
memory: 26720kb

Test #32:

score: 0
Accepted
time: 789ms
memory: 26076kb

Test #33:

score: 0
Accepted
time: 800ms
memory: 26836kb

Test #34:

score: 0
Accepted
time: 789ms
memory: 24500kb

Test #35:

score: 0
Accepted
time: 789ms
memory: 24452kb

Subtask #8:

score: 10
Accepted

Test #36:

score: 10
Accepted
time: 2311ms
memory: 40576kb

Test #37:

score: 0
Accepted
time: 2342ms
memory: 41380kb

Test #38:

score: 0
Accepted
time: 2334ms
memory: 40280kb

Test #39:

score: 0
Accepted
time: 2342ms
memory: 41628kb

Test #40:

score: 0
Accepted
time: 2325ms
memory: 40436kb

Subtask #9:

score: 10
Accepted

Dependency #8:

100%
Accepted

Test #41:

score: 10
Accepted
time: 2328ms
memory: 40600kb

Test #42:

score: 0
Accepted
time: 2361ms
memory: 41072kb

Test #43:

score: 0
Accepted
time: 2338ms
memory: 41240kb

Test #44:

score: 0
Accepted
time: 2326ms
memory: 40872kb

Test #45:

score: 0
Accepted
time: 2349ms
memory: 40472kb

Subtask #10:

score: 15
Accepted

Dependency #1:

100%
Accepted

Dependency #2:

100%
Accepted

Dependency #3:

100%
Accepted

Dependency #4:

100%
Accepted

Dependency #5:

100%
Accepted

Dependency #6:

100%
Accepted

Dependency #7:

100%
Accepted

Dependency #8:

100%
Accepted

Dependency #9:

100%
Accepted

Test #46:

score: 15
Accepted
time: 4872ms
memory: 41616kb

Test #47:

score: 0
Accepted
time: 4910ms
memory: 41464kb

Test #48:

score: 0
Accepted
time: 4883ms
memory: 41468kb

Test #49:

score: 0
Accepted
time: 4882ms
memory: 41592kb

Test #50:

score: 0
Accepted
time: 4884ms
memory: 41628kb