社区讨论

这题莫队只有32pts吗……

P1972[SDOI2009] HH 的项链参与者 3已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@lo8j3m2u
此快照首次捕获于
2023/10/27 19:27
2 年前
此快照最后确认于
2023/10/27 19:27
2 年前
查看原帖
TLE32分,求帮忙看看莫队哪写挂了,感谢
CPP
#include<bits/stdc++.h>
#define bel(x) ((x-1)/sq+1)
using namespace std;
const int N=1e6+100;
int n,a[N],q,cnt[N],ans,sq;
vector<pair<pair<int,int>,int>>Q;
vector<pair<int,int>>Ans;
void add(int x){
    if(!cnt[a[x]]) ans++;
    cnt[a[x]]++;
}
void del(int x){
    cnt[a[x]]--;
    if(!cnt[a[x]]) ans--;
}
bool cmp(pair<pair<int,int>,int> x,pair<pair<int,int>,int> y){
    if(bel(x.first.first)==bel(y.first.first)) return bel(x.first.second)<bel(y.first.second);
    return bel(x.first.first)<bel(y.first.first);
}

int main(){
    ios::sync_with_stdio(false);
    cin.tie(0),cout.tie(0);
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];sq=sqrt(n);
    cin>>q;for(int i=1;i<=q;i++){
        pair<int,int>t;cin>>t.first>>t.second;Q.push_back({t,i});}
    int l=1,r=0;
    sort(Q.begin(),Q.end(),cmp);
    for(auto i:Q){
        while(l>i.first.first) add(--l);
        while(r<i.first.second) add(++r);
        while(l<i.first.first) del(l++);
        while(r>i.first.second)del(r--);
        Ans.push_back({i.second,ans});
    }
    sort(Ans.begin(),Ans.end());
    for(auto i:Ans){cout<<i.second<<"\n";}
}

回复

5 条回复,欢迎继续交流。

正在加载回复...