zoukankan      html  css  js  c++  java
  • 经典树状数组/线段树思想学习——[SDOI2009]HH的项链/NOI.ac#44. color

    HH的项链

    #include<cstdio>
    #include<vector>
    
    inline void input(int &x){
    	int ans=0,f=1;
    	char c=getchar();
    	while(c>'9'||c<'0'){
    		if(c=='-')f=-1;
    		c=getchar();
    	}
    	while(c>='0'&&c<='9'){
    		ans=(ans<<1)+(ans<<3)+(c-48);
    		c=getchar();
    	}
    	x=ans*f;
    }
    
    inline void output(int x){
    	if(x<0)putchar('-'),x=-x;
    	if(x>9)output(x/10);
    	putchar(x%10+48);
    }
    
    inline void writeln(int x){
    	output(x);
    	putchar('
    ');
    }
    
    int n,m,c[1000005],a[1000005],left[1000005],right[1000005],
    	last[1000005],out[1000005],now[1000005];
    
    std::vector<int> zhi[1000005];
    
    inline int lowbit(int x){
    	return x&(-x);
    }
    
    inline void add(int now,int x){
    	while(now<=n){
    		c[now]+=x;
    		now+=lowbit(now);
    	}
    }
    
    inline int sum(int now){
    	int ans=0;
    	while(now){
    		ans+=c[now];
    		now-=lowbit(now);
    	}
    	return ans;
    }
    
    int main(){
    	scanf("%d",&n);
    	for(int i=1;i<=n;i++){
    		scanf("%d",&a[i]);
    		last[i]=now[a[i]];
    		now[a[i]]=i;
    	}
    	scanf("%d",&m);
    	for(int i=1;i<=m;i++){
    		scanf("%d%d",&left[i],&right[i]);
    		zhi[right[i]].push_back(i);
    	}
    	for(int i=1;i<=n;i++){
    		if(last[i])add(last[i],-1);
    		add(i,1);
    		for(int j=0;j<zhi[i].size();j++){
    			out[zhi[i][j]]=sum(right[zhi[i][j]])-sum(left[zhi[i][j]]-1);
    		//	printf("%d %d
    ",zhi[i][j],out[zhi[i][j]]);
    		}
    	}
    	for(int i=1;i<=m;i++){
    		printf("%d
    ",out[i]);
    	}
    }
    

    进阶:屠龙宝刀点击就送

    怎么连码风也进阶了

    #include<cstdio>
    #include<algorithm>
    
    int n,m,k,t,a[500005],tot[500005],id[500005],now[500005],
    	nex[500005],last[500005],fir[500005],ans[500005],fa[500005];
    
    struct BIT{
    	int C[500005];
    	inline int lowbit(int X){return X&(-X);}
    	inline void add(int K,int X){
    		while(K<=n){
    			C[K]+=X;
    			K+=lowbit(K);
    		}
    	}
    	inline int query(int K){
    		int ANS=0;
    		while(K){
    			ANS+=C[K];
    			K-=lowbit(K);
    		}
    		return ANS;
    	}
    }T;
    
    struct ask{
    	int id,l,r;
    }e[500005];
    
    inline bool cmp(ask x,ask y){return x.r<y.r;}
    
    int main(){
    	scanf("%d%d%d%d",&n,&m,&k,&t);
    	for(int i=1;i<=n;i++){
    		scanf("%d",&a[i]);
    		tot[a[i]]++;
    		id[i]=tot[a[i]];
    		nex[last[a[i]]]=i;
    		fa[i]=last[a[i]];
    		last[a[i]]=i;
    		if(!fir[a[i]])fir[a[i]]=i;
    	}
    	for(int i=1;i<=m;i++){
    		scanf("%d%d",&e[i].l,&e[i].r);
    		e[i].id=i;
    	}
    	std::sort(e+1,e+m+1,cmp);
    	for(int i=1,qvq=1;i<=n;i++){
    		if(id[i]==t){
    			T.add(fir[a[i]],1);
    			now[a[i]]=fir[a[i]];
    		}
    		else if(id[i]>t){
    			T.add(now[a[i]],-1);
    			if(fa[now[a[i]]])T.add(fa[now[a[i]]],1);//
    			T.add(nex[now[a[i]]],1);
    			T.add(now[a[i]],-1);//
    			now[a[i]]=nex[now[a[i]]];
    		}
    		while(e[qvq].r==i){
    			ans[e[qvq].id]=T.query(i)-T.query(e[qvq].l-1);
    		//	printf("%d %d %d %d
    ",e[qvq].l,e[qvq].r,e[qvq].id,ans[e[qvq].id]);
    			qvq++;
    		}
    	}
    	for(int i=1;i<=m;i++)printf("%d
    ",ans[i]);
    }
    
  • 相关阅读:
    Java操作zip压缩和解压缩文件工具类
    Java操作图片的工具类
    使用Jacob操作Wrod文档的工具类代码
    Java计算文件的SHA码和MD5码
    Java 文件名操作的相关工具类
    Java中windows路径转换成linux路径等工具类
    JDBC的批量批量插入
    显示创建一个表的SQL语句
    MySQL中的保留字
    插入到Mysql数据库中的汉字乱码
  • 原文地址:https://www.cnblogs.com/Y15BeTa/p/11845310.html
Copyright © 2011-2022 走看看