SPOJ3267/DQUERY:D-query——题解
https://vjudge.net/problem/SPOJ-DQUERY
http://www.spoj.com/problems/DQUERY/en/
给定一列数,查询给定区间内数的种类数。
这题可以分块做:BZOJ2453:维护队列
但是我们不想分块而且垃圾SPOJ可能会卡时间同时又想练主席树,所以选择主席树。
参考:https://www.cnblogs.com/zhuanzhuruyi/p/5936713.html
这种题的主席树建法并不是权值线段树,而是正常线段树。
当我们建树过程中碰到的重复的数的时候,显然让该重复的数接近r是最好的,所以我们把前面的数删掉,放到后面。
查询的时候就是查询rt[0]~rt[r],并且查询的范围在l~r的数的个数即可。
PS:rt[0]相当于没有,范围的上限r也可以省略。
#include<stack>
#include<queue>
#include<cstdio>
#include<cstring>
#include<bitset>
#include<algorithm>
using namespace std;
const int N=1e6+;
inline int read(){
int x=,w=;char ch=;
while(ch<''||ch>''){if(ch=='-')w=-;ch=getchar();}
while(ch>=''&&ch<=''){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*w;
}
struct tree{
int l,r,sum;
}tr[N*];
int n,m,rt[N],pool,in[N];
inline void insert(int y,int &x,int l,int r,int p,int v){
tr[x=++pool]=tr[y];
tr[x].sum+=v;
if(l==r)return;
int mid=(l+r)>>;
if(p<=mid)insert(tr[y].l,tr[x].l,l,mid,p,v);
else insert(tr[y].r,tr[x].r,mid+,r,p,v);
}
inline int query(int x,int l,int r,int p){
if(p<=l)return tr[x].sum;
if(r<p)return ;
int mid=(l+r)>>;
return query(tr[x].l,l,mid,p)+query(tr[x].r,mid+,r,p);
}
int main(){
n=read();
for(int i=;i<=n;i++){
int a=read(),tmp;
if(!in[a]){
insert(rt[i-],rt[i],,n,in[a]=i,);
}else{
insert(rt[i-],tmp,,n,in[a],-);
insert(tmp,rt[i],,n,in[a]=i,);
}
}
m=read();
for(int i=;i<=m;i++){
int l=read(),r=read();
printf("%d\n",query(rt[r],,n,l));
}
return ;
}
+++++++++++++++++++++++++++++++++++++++++++
+本文作者:luyouqi233。 +
+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+
+++++++++++++++++++++++++++++++++++++++++++
SPOJ3267/DQUERY:D-query——题解的更多相关文章
- SPOJ3267 D-query 离线+树状数组 在线主席树
		分析:这个题,离线的话就是水题,如果强制在线,其实和离线一个思路,然后硬上主席树就行了 离线的代码 #include <iostream> #include <stdio.h> ... 
- [SP3267]DQUERY - D query
		题目传送门 维护一个区间内不同数的个数,最直观的想法是直接排序后用树状数组维护即可.但是我们发现n只有3e4,于是我们想到了可以拿一个$O(n\sqrt{n})$的莫队维护.关于莫队算法如果有不知道的 ... 
- 【HDU5869】 Different GCD Subarray Query 题解 (线段树维护区间GCD)
		题目大意:求区间$[L,R]$中所有子区间产生的最大公因数的个数. ------------------------- 对于$gcd$,我们知道$gcd(a,b,c)=gcd(gcd(a,b),c)$ ... 
- BZOJ3236:[AHOI2013]作业——题解
		https://www.lydsy.com/JudgeOnline/problem.php?id=3236 第一种做法: 建两棵主席树分别处理两个问题. 第一个问题水,第二个问题参考SPOJ3267/ ... 
- 莫队算法学习笔记【BZOJ2038:小Z的袜子】【SPOJ3267:D-query】
		很久以前傻乎乎地看来源奇怪的资料的时候被各种曼哈顿弄晕了. 然后现在学会的是分块方法.另新创一个分块方法. 让我们考虑这样一个区间询问问题…… 它有如下的性质: 0,n个数,Q个询问. 1,它没有修改 ... 
- SPOJ3267:D-query
		题面 SPOJ3267 Sol 给定\(N\)个正整数构成的序列,将对于指定的闭区间查询其区间内的不同的数的个数 主席树 不是权值线段树 维护位置 如果插入一个数时发现之前有过了 那么修改当前的,那个 ... 
- 【题解】Luogu SP3267 DQUERY - D-query
		原题传送门 这题和Luogu P1972 [SDOI2009]HH的项链很像,只是数据大小有些差别,题解 我博客里对莫队的介绍 我们在排序询问时,普通是这样qaq inline bool cmp(re ... 
- HDU3686 Traffic Real Time Query System 题解
		题目 City C is really a nightmare of all drivers for its traffic jams. To solve the traffic problem, t ... 
- 【题解】【数组】【Prefix Sums】【Codility】Genomic Range Query
		A non-empty zero-indexed string S is given. String S consists of N characters from the set of upper- ... 
随机推荐
- iOS性能调优工具
			总结: 三类工具 基础工具 (NSLog的方式记录运行时间.) 性能工具.检测各个部分的性能表现,找出性能瓶颈 内存工具.检查内存正确性和内存使用效率 性能工具: 可以衡量CPU的使用,时间的消耗,电 ... 
- Sublime Text 插件推荐——for web developers
			楼主向高大上的: web front-end development engineer (好吧,google就是这样翻译的 ^_^)们推荐 ST 插件,在此抛砖引玉: NO.1 :Emmet (原名: ... 
- “Hello world!”团队第一周贡献分分配结果
			小组名称:Hello World! 项目名称:空天猎 组长:陈建宇 成员:刘成志.阚博文.刘淑霞.黄泽宇.方铭.贾男男 第一周贡献分分配结果 基础分 会议分 提功能分 个人表现分 各项总分 最终分 ... 
- 第八次作业——项目UML设计
			分工及贡献分评定 成员 参与 贡献比例 朱跃安(031602348) 类图 13% 后敬甲(031602409) 实体关系图+博客整理 14.5% 林志华(031602128) 用例图+活动图 14. ... 
- Java核心技术点之接口
			1. 为什么使用接口 Java中的接口是一组对需求的描述.接口通过声明接口方法来对外宣布:“要想具有XX功能,就得按我说的做(即实现接口方法).” 而接口的实现类通过实现相应接口的方法来宣布:“我已经 ... 
- MFC消息处理
			1.MFC窗口如何与AfxWndProc建立联系. 当一个新的CWnd派生类创建时,在调用CWnd::CreateEx()过程中,MFC都会安装AfxCbtFilterHook().这个Hook将拦截 ... 
- Swift-枚举enum理解
			//定义一个枚举 //枚举的语法,enum开头,每一行成员的定义使用case关键字开头,一行可以定义多个关键字 enum CompassPoint { case North case South ca ... 
- TCP系列06—连接管理—5、TCP  fastopen(TFO)
			一.TFO背景 当前web和web-like应用中一般都是在三次握手后开始数据传输,相比于UDP,多了一个RTT的时延,即使当前很多应用使用长连接来处理这种情况,但是仍然由一定比例的短连接,这额外多出 ... 
- #Leetcode# 951. Flip Equivalent Binary Trees
			https://leetcode.com/problems/flip-equivalent-binary-trees/ For a binary tree T, we can define a fli ... 
- linux下清空文件全部内容,如log日志
			在实际操作中经常需要清空log文件, 比如a.log, 有的人说, 直接删除不就行了, 但是, 直接删除后, 没法使用tail -f a.log了. 有的人说, 先rm再touch一个新文件不就可 ... 
