全RE求调
查看原帖
全RE求调
473401
zcxnb楼主2025/1/1 11:44
#include<bits/stdc++.h>
using namespace std;
const int N=5e5+5,M=710;
int n,m,t,block,cnt;
int a[N],pos[N],st[M],en[M],id[N],b[N],bar[N],mode[M][M];
vector<int>v[N];
map<int,int>mp;
void dis(){
    sort(b+1,b+1+n);
    cnt=unique(b+1,b+1+n)-b-1;
    for(int i=1;i<=cnt;i++){
        mp[b[i]]=i;
    }
    for(int i=1;i<=n;i++){
        a[i]=mp[a[i]];
    }
}
void allocate(){
    block=(int)sqrt(n);
    t=n/block;
    if(n%block)  t++;
    for(int i=1;i<=t;i++){
        st[i]=(i-1)*block+1;
        en[i]=i*block;
    }
    en[t]=n;
    for(int i=1;i<=n;i++){
        pos[i]=(i-1)/block+1;
    }
}
void preprocess(){
    for(int i=1;i<=n;i++){
        v[a[i]].push_back(i);
        id[i]=v[a[i]].size()-1;
    }
    for(int i=1;i<=t;i++){
        int res=0;
        for(int j=i;j<=t;j++){
            for(int k=st[j];k<=en[j];k++){
                bar[a[i]]++;
                if(bar[a[i]]>bar[res])  res=a[i];
            }
            mode[i][j]=bar[res];
        }
        for(int j=1;j<=cnt;j++){
            bar[j]=0;
        }
    }
}
int query(int l,int r){
    int p=pos[l],q=pos[r],res=0,ans=0;
    if(p==q){
        for(int i=l;i<=r;i++){
            bar[a[i]]++;
            if(bar[a[i]]>bar[res])  res=a[i];
        }
        ans=bar[res];
        for(int i=l;i<=r;i++)  bar[a[i]]=0;
    }
    else{
        ans=mode[p+1][q-1];
        for(int i=en[p];i>=l;i--){
            int num=id[i]+ans;
            if(num>v[a[i]].size())  continue;
            if(v[a[i]][num]<=r)  ans++;
        }
        for(int i=st[q];i<=r;i++){
            int num=id[i]-ans;
            if(num<0)  continue;
            if(v[a[i]][num]>=l)  ans++;
        }
    }
    return ans;
}
int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    dis();
    allocate();
    preprocess();
    int x=0;
    for(int i=1;i<=m;i++){
        int l,r;
        scanf("%d%d",&l,&r);
        l^=x,r^=x;
        x=query(l,r);
        printf("%d\n",x);
    }
}
2025/1/1 11:44
加载中...