数据结构(主席树):HZOI 2016 采花
【题目描述】
给定一个长度为n,包含c种颜色的序列,有m个询问,每次给出两个数l,r,表示询问区间[l,r]中有多少种颜色的出现次数不少于2次。
本题强制在线,对输入的l,r进行了加密,解密方法为:
l = l' xor lastans
r = r' xor lastans
其中l', r'为输入的l和r,xor表示异或,lastans为上一次询问的答案且初始值为0。
【输入格式】
第一行三个正整数n,c,m,意义与题目描述中的相同。
第二行n个位于[1,c]内的正整数,表示序列上每个位置的颜色。
以下m行每行两个位于[1,n]的整数l,r(l<=r),分别描述每个询问。
【输出格式】
对于每个询问,单独一行输出结果。
对于每个测试点,如果你的每个答案均与标准答案相同,则你可得到该测试点所有分数,否则你将失去该测试点所有分数。
【样例输入】
15 5 10
4 2 3 2 5 5 2 2 4 4 2 5 4
1 3
1 1
2 5
12 14
10 13
10 12
2 11
2 13
7 5
5 6
5 10
【样例输出】
0
1
0
1
0
3
3
1
2
1
【样例解释】
样例输入解密后为
15 5 10
4 2 3 2 5 5 2 2 4 4 2 5 4
1 3
1 1
2 5
13 15
10 13
11 13
2 11
1 14
4 6
4 7
7 8
【数据范围】
对于30%的数据,n,m,c<=100。
对于50%的数据,n,m<=50000,c<=100。
对于100%的数据,n,m,c<=200000。
发现n,m比较小,又强制在线,于是考虑用主席树。
分析计数的方法,我们对于一个区间中相同的数,找出来,记录后面至少有一个相同数的数的个数,再记录后面至少有两个相同数的数的个数,再相减,就是这种颜色对答案的贡献,用主席树分裂区间,查询个数即可。
#include <iostream>
#include <cstring>
#include <cstdio>
#define mid ((l+r)>>1)
using namespace std;
const int N=;
int cnt,n,c,Q,a[N],p[N],p1[N];
int rt[N*],ch[N*][],sum[N*];
void Insert(int pre,int &rt,int l,int r,int g){
sum[rt=++cnt]=sum[pre]+;
ch[rt][]=ch[pre][];
ch[rt][]=ch[pre][];
if(l==r)return;
if(mid>=g)Insert(ch[pre][],ch[rt][],l,mid,g);
else Insert(ch[pre][],ch[rt][],mid+,r,g);
} int Query(int pre,int rt,int l,int r,int a,int b){
if(l>=a&&r<=b){return sum[rt]-sum[pre];}int ret=;
if(mid>=a)ret=Query(ch[pre][],ch[rt][],l,mid,a,b);
if(mid<b)ret+=Query(ch[pre][],ch[rt][],mid+,r,a,b);
return ret;
}
int main(){
freopen("flower++.in","r",stdin);
freopen("flower++.out","w",stdout);
scanf("%d%d%d",&n,&c,&Q);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=;i<=n;i++){
if(p[a[i]])Insert(rt[i-],rt[i],,n,p[a[i]]);else rt[i]=rt[i-];
if(p1[a[i]])Insert(rt[n+i],rt[n+i+],,n,p1[a[i]]);else rt[n+i+]=rt[n+i];
p1[a[i]]=p[a[i]];p[a[i]]=i;
}
int ans=,l,r;
while(Q--){
scanf("%d%d",&l,&r);l^=ans;r^=ans;
ans=Query(rt[l-],rt[r],,n,l,r);
ans-=Query(rt[n+l],rt[n+r+],,n,l,r);
printf("%d\n",ans);
}
return ;
}
数据结构(主席树):HZOI 2016 采花的更多相关文章
- 数据结构(主席树):COGS 2211. 谈笑风生
2211. 谈笑风生 ★★★★ 输入文件:laugh.in 输出文件:laugh.out 简单对比时间限制:3 s 内存限制:512 MB [问题描述] 设T 为一棵有根树,我们做如下 ...
- HYSBZ 4551 (树状数组) 采花
题目:这里 题意: 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为1),有以下 两种操作:1. 标记操作:对某个结点打上标记(在最开始,只有结点1有标记, ...
- HYSBZ 2743 (树状数组) 采花
题目:这里 题意: 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为1),有以下 两种操作:1. 标记操作:对某个结点打上标记(在最开始,只有结点1有标记, ...
- 数据结构(主席树):HDU 5654 xiaoxin and his watermelon candy
Problem Description During his six grade summer vacation, xiaoxin got lots of watermelon candies fro ...
- 数据结构(主席树):COGS 2213. K个串
2213. K个串 ★★★★ 输入文件:bzoj_4504.in 输出文件:bzoj_4504.out 简单对比时间限制:20 s 内存限制:512 MB [题目描述] 兔子们在玩k个 ...
- 数据结构(树状数组):HEOI2012 采花
[题目描述] 萧薰儿是古国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一排的,以便 ...
- BZOJ 2743: [HEOI2012]采花 [树状数组 | 主席树]
题意: 查询区间中出现次数$>2$的颜色个数 一眼主席树,区间中$l \le last[i] \le r$的个数减去$l \le last[last[i]] \le r$的个数,搞两颗主席树来做 ...
- BZOJ_2743_[HEOI2012]采花_离线+树状数组
BZOJ_2743_[HEOI2012]采花_离线+树状数组 Description 萧芸斓是Z国的公主,平时的一大爱好是采花.今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花 .花园足够大 ...
- BZOJ 2743: [HEOI2012]采花 离线树状数组
2743: [HEOI2012]采花 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2743 Description 萧芸斓是Z国的公主, ...
随机推荐
- json 是什么
怎么学习一个知识? 首先要提出几个问题,目前认为json是个什么,json是谁创造的,为什么而出现的,但是目前仅有很长时间之前别人直接告诉我的,json用来存数据的,对于使用也忘记的差不多了,所以现在 ...
- SQL 中case when then else 用法
SQL如下: SELECT DISTINCTsy_haken_type,sy_sagyo_type,sy_kokyaku_cdFROm tbl_syukeiWHERE (sy_sagyo_ymd be ...
- AngularJs的UI组件ui-Bootstrap-Tooltip
完整案例,参考http://www.cnblogs.com/pilixiami/p/5661600.html <!DOCTYPE html> <html ng-app="u ...
- iOS中常用技术链接
1.弹幕技术 http://www.jianshu.com/p/f39b8abc8008 2.通过CAGradientLayer制作渐变色效果 http://blog.it985.com/7986.h ...
- 回退符\b
回退符\b #include <stdio.h> int main(){ printf("hello\b"); getchar(); getchar(); ; } 实验 ...
- 手机定位原理 - GPS/GLONASS/北斗 + WIFI + 基站
卫星定位系统 - GPS/GLONASS/北斗: 关于GPS.GLONASS.北斗.伽利略系统的科普请自行谷歌. GPS是使用最广泛的全球定位网络,几乎是所有智能手机的标配.进几年,俄罗斯的GLONA ...
- URL 路由访问报错
错误: 错误分析: 控制器的文件名命名有问题(index.php) 在TP中控制器命名规范(IndexController.class.php) 相信许多PHP开发者在使用ThinkPHP ...
- 在win10 64位下编译,提示[C++ Error] E2075 Incorrect project override option: (x86)\borland\cbuilder6\lib\vcl60.csm
options->compiler 右边有个file name 改下就好了从$(BCB)\lib\vcl60.csm 改为c:\PROGRA~1\borland\CBUILD~1\lib\vc ...
- CSS3中的选择器
首先, CSS即层叠样式表(Cascading StyleSheet) CSS3是CSS技术的升级版本,CSS3语言开发是朝着模块化发展的 模块包括: 盒子模型.列表模块.超链接方式 .语言模块 .背 ...
- php中include文件夹分析
include是包含很多php文件的一种汇总:一般放在文件夹最外层. <?php header("content-type:text/html;charset=utf-8") ...