刚学莫队的小蒟蒻求助,为什么会RE?
查看原帖
刚学莫队的小蒟蒻求助,为什么会RE?
510360
HbugU楼主2021/7/8 08:09

样例都过了,为什么会RE。

#include<bits/stdc++.h>
#define ll long long
#define ull unsigned long long
#define fr first
#define se second
#define FAST ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
using namespace std;
int n,q,a[30005],curl=1,curr=0,ans,cnt[30005],bl,answer[1010000]; 
struct query{
	int id,l,r;
}que[1010000];
void add(int pos){
	if(!cnt[a[pos]]) ++ans;
	++cnt[a[pos]];
}
void del(int pos){
	--cnt[a[pos]];
	if(!cnt[a[pos]]) --ans;
}
bool cmp(query x,query y){
	return (x.l/bl)==(y.l/bl)?x.r<y.r:x.l<y.l;
}
int main(){
	FAST;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	cin>>q;
	bl=sqrt(n);
	for(int i=1;i<=q;i++){
		cin>>que[i].l>>que[i].r;
		que[i].id=i;
	}
	sort(que+1,que+1+q,cmp);
	for(int i=1;i<=q;i++){
		int ql=que[i].l,qr=que[i].r;
		while(curl<ql) del(curl++);
		while(curl>ql) add(--curl);
		while(curr>qr) del(curr--);
		while(curr<qr) add(++curr);
		answer[que[i].id]=ans;
	}
	for(int i=1;i<=q;i++){
		cout<<answer[i]<<endl;
	}
	return 0;
}
2021/7/8 08:09
加载中...