P2709 小B的詢問(莫隊)
阿新 • • 發佈:2019-03-25
ext cmp col cstring define while return get std
P2709 小B的詢問
莫隊模板
資磁離線詢問
維護兩個跳來跳去的指針
先分塊,藍後詢問按塊排序。
藍後每次指針左右橫跳更新答案
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #include<cmath> using namespace std; #define N 50005 struct data{int x,y,t;}a[N]; int n,m,k,Len,b[N],c[N],ans[N],tot,L,R; inlineint bel(int x){return (x-1)/Len+1;} inline bool cmp(data A,data B){ return bel(A.x)==bel(B.x)?bel(A.y)<bel(B.y):bel(A.x)<bel(B.x); } inline void Del(int x){tot-=c[b[x]]*2-1,--c[b[x]];} inline void Add(int x){tot+=c[b[x]]*2+1,++c[b[x]];} int main(){ scanf("%d%d%d",&n,&m,&k);Len=sqrt(n); registerint i; for(i=1;i<=n;++i) scanf("%d",&b[i]); for(i=1;i<=m;++i) scanf("%d%d",&a[i].x,&a[i].y),a[i].t=i; sort(a+1,a+m+1,cmp); L=R=1; c[b[1]]=tot=1; for(i=1;i<=m;++i){ while(L<a[i].x) Del(L++); while(L>a[i].x) Add(--L); while(R>a[i].y) Del(R--); while(R<a[i].y) Add(++R); ans[a[i].t]=tot; } for(i=1;i<=m;++i) printf("%d\n",ans[i]); return 0; }
P2709 小B的詢問(莫隊)