Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题。
对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数。
为了方便,我们规定妹子们的美丽度全都在[1,n]中。
给定一个长度为n(1<=n<=100000)的正整数序列s(1<=si<=n),对于m(1<=m<=1000000)次询问“l,r,a,b”,每次输出sl...sr中,权值∈[a,b]的权值的种类数。
标签:lag cat tput 难题 exp images ima algorithm pair
对每个询问,单独输出一行,表示sl...sr中权值∈[a,b]的权值的种类数。
分块+莫队
我们用一个cnt[j]表示第i个询问时j出现次数
我们维护每个块中有多少个元素(第一次?第一次被查询+第一次出现过),我们只要用val数组记录一下某个块有多少个数被维护
假设我们某一次询问移动l,r导致其减成0,我们就更新答案
具体来说我也不是很懂 %一发Flere825
/*To The End Of The Galaxy*/ #include<cstdio> #include<cstdlib> #include<iostream> #include<cstring> #include<algorithm> #include<queue> #include<iomanip> #include<stack> #include<map> #include<set> #include<cmath> #include<complex> #define debug(x) cerr<<#x<<"="<<x<<endl #define INF 0x7f7f7f7f #define llINF 0x7fffffffffffll using namespace std; typedef pair<int,int> pii; typedef long long ll; inline int init() { int now=0,ju=1;char c;bool flag=false; while(1) { c=getchar(); if(c==‘-‘)ju=-1; else if(c>=‘0‘&&c<=‘9‘) { now=now*10+c-‘0‘; flag=true; } else if(flag)return now*ju; } } inline long long llinit() { long long now=0,ju=1;char c;bool flag=false; while(1) { c=getchar(); if(c==‘-‘)ju=-1; else if(c>=‘0‘&&c<=‘9‘) { now=now*10+c-‘0‘; flag=true; } else if(flag)return now*ju; } } struct node { int l,r,a,b,id,ans; }query[1000101]; int n,m; int bel[100001]; int block,divi; int ans; #define pos(x) (((x-1)/block)+1) bool cmp(node a,node b) { if(pos(a.l)!=pos(b.l)) { return pos(a.l)<pos(b.l); } else return a.r<b.r; } bool cmpid(node a,node b) { return a.id<b.id; } int cnt[100005],val[100005]; int a[100005]; inline void Plus(int p) { cnt[a[p]]++; if(cnt[a[p]]==1)val[bel[a[p]]]++; } inline void Minus(int p) { cnt[a[p]]--; if(cnt[a[p]]==0)val[bel[a[p]]]--; } inline int ask(int l,int r) { int ans=0; if(bel[l]==bel[r]) { for(int i=l;i<=r;i++) { if(cnt[i])ans++; } return ans; } for(int i=l;i<=bel[l]*divi;i++) { if(cnt[i]) { ans++; } } for(int i=((bel[r]-1)*divi)+1;i<=r;i++) { if(cnt[i]) { ans++; } } for(int i=bel[l]+1;i<bel[r];i++) { ans+=val[i]; } return ans; } int main() { int l=1,r=0; n=init();m=init(); block=sqrt(m); divi=sqrt(n); for(int i=1;i<=n;i++) { a[i]=init(); bel[i]=((i-1)/divi)+1; } for(int i=1;i<=m;i++) { query[i].l=init();query[i].r=init();query[i].a=init();query[i].b=init(); query[i].id=i; } sort(query+1,query+1+m,cmp); for(int i=1;i<=m;i++) { if(query[i].r>r) { for(r=r+1;r<=query[i].r;r++) { Plus(r); } } else if(query[i].r<r) { for(;r>query[i].r;r--) { Minus(r); } } if(query[i].l>l) { for(;l<query[i].l;l++) { Minus(l); } } else if(query[i].l<l) { for(l=l-1;l>=query[i].l;l--) { Plus(l); } } l=query[i].l;r=query[i].r; query[i].ans=ask(query[i].a,query[i].b); } sort(query+1,query+1+m,cmpid); for(int i=1;i<=m;i++) { printf("%d\n",query[i].ans); } return 0; } /* srO xudyh davidlee1999WTK linkct1999 Orz compiler TDM-GCC 5.9.2 */
标签:lag cat tput 难题 exp images ima algorithm pair
原文地址:http://www.cnblogs.com/redwind/p/6501928.html