[bzoj2743][HEOI2012]采花_树状数组
采花 bzoj-2743 HEOI-2012
题目大意:给定n朵花,每朵花有一个种类,m次询问:一段区间中至少出现两朵花的种类的个数。
注释:$1\le n,m\le10^6$。
想法:这个题超级像HH的项链
就是把那个题的$nxt$往后再延迟一个更新即可。
最后,附上丑陋的代码... ...
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #define RR register
- #define N 1000010
- using namespace std;
- inline char nc() {static char *p1,*p2,buf[100000]; return (p1==p2)&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;}
- int read()
- {
- int x=0; char c=nc();
- while(!isdigit(c)) c=nc();
- while(isdigit(c)) x=(x<<3)+(x<<1)+c-'0',c=nc();
- return x;
- }
- struct Node
- {
- int l,r,id,ans;
- }q[N];
- int nxt[N],tree[N],a[N],p[N],n;
- inline bool cmp1(const Node &x,const Node &y)
- {
- return x.l==y.l?x.r<y.r:x.l<y.l;
- }
- inline bool cmp2(const Node &x,const Node &y)
- {
- return x.id<y.id;
- }
- inline int lowbit(int x) {return x&(-x);}
- void update(int x,int val)
- {
- for(RR int i=x;i<=n+1;i+=lowbit(i))
- {
- tree[i]+=val;
- }
- }
- int query(int x)
- {
- int ans=0;
- for(RR int i=x;i>=1;i-=lowbit(i))
- {
- ans+=tree[i];
- }
- return ans;
- }
- int main()
- {
- n=read();
- int mx=read(),m=read();
- for(RR int i=1;i<=n;i++) a[i]=read();
- for(RR int i=n;i>=1;i--)
- {
- nxt[i]=p[a[i]];
- p[a[i]]=i;
- }
- for(RR int i=1;i<=mx;i++)
- {
- if(p[i]&&nxt[p[i]]) update(nxt[p[i]],1);
- }
- for(RR int i=1;i<=m;i++) q[i].l=read(),q[i].r=read(),q[i].id=i;
- sort(q+1,q+m+1,cmp1);
- int l=1;
- for(RR int i=1;i<=m;i++)
- {
- while(l<q[i].l)
- {
- if(nxt[l]) update(nxt[l],-1);
- if(nxt[nxt[l]]) update(nxt[nxt[l]],1);
- l++;
- }
- q[i].ans=query(q[i].r)-query(q[i].l-1);
- }
- sort(q+1,q+m+1,cmp2);
- for(RR int i=1;i<=m;i++)
- {
- printf("%d\n",q[i].ans);
- }
- return 0;
- }
小结:对于这种询问种类的题要是可以离线的话就这个做法,要是强制在线就得上树套树了。

[bzoj2743][HEOI2012]采花_树状数组的更多相关文章
- [bzoj2743][HEOI2012]采花(树状数组)
题目描述 萧薰儿是古国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花. 花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一排的,以便于 ...
- bzoj2743: [HEOI2012]采花--离线树状数组+差分
题目大意:给定一个区间,查询子区间里出现次数不小于二的数的个数 此题想了好久没想出来,后来是在网上学习的一个方法 首先按查询区间的右端点进行排序,按右端点从小到大处理 假设pre[a[i]]是与a[i ...
- 【BZOJ2743】[HEOI2012]采花 离线+树状数组
[BZOJ2743][HEOI2012]采花 Description 萧芸斓是Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花, ...
- BZOJ 2743: [HEOI2012]采花 离线树状数组
2743: [HEOI2012]采花 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2743 Description 萧芸斓是Z国的公主, ...
- bzoj 2743: [HEOI2012]采花【树状数组】
离线,按照l排序 注意到在区间里出现两次的颜色才有贡献,所以记录一个ne[i]表示i后第一个和i同色的花,维护一个l,每次处理询问的时候l单调右移,树状数组维护,在ne[ne[i]]位置++,在ne[ ...
- 【BZOJ】2743: [HEOI2012]采花(树状数组)
题目 传送门:QWQ 分析 已经凉凉.看错数据范围敲了发莫队........ 和HH的项链差不多,把每种颜色之前的颜色到再之前的颜色这段区间 区间加. 区间加就树状数组特技 代码 #include & ...
- [HEOI2012]采花(树状数组+离线)
听说这题的所发和HH的项链很像. 然而那道题我使用莫队写的... 这是一个套路,pre数组加升维(在线). 记录一个\(pre\)数组,\(pre[i]\)代表上一个和i颜色相同的下标. 我们把询问离 ...
- BZOJ 2743 采花(树状数组)
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2743 题意:给出一个数列,每个询问查询[L,R]中至少出现两次的数字有多少种? 思路:(1 ...
- BZOJ_2743_[HEOI2012]采花_离线+树状数组
BZOJ_2743_[HEOI2012]采花_离线+树状数组 Description 萧芸斓是Z国的公主,平时的一大爱好是采花.今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花 .花园足够大 ...
随机推荐
- 7.2 高速缓冲存储器-Cache
高速缓冲存储器:Cache.Cache的功能是提高CPU数据的输入和输出的速率.CPU的速度与主存的速度之间有巨大的差异.主存的存取时间.存取速度要比CPU的速度要慢了很多倍.为了调和它们之间的巨大速 ...
- 网页分享URL
<a href="tencent://Message/?Uin=QQ号码&Site=qq联系">点击联系</a> 1.新浪微博:<a href ...
- java enum int String 相互转换
1. enum<->int enum -> int: int i = enumType.value.ordinal(); int -> enum: enumType b= e ...
- github 用户不被识别问题
期末考完,继续开发. 用过的都知道,直接用的话贡献者上面显示不出自己. 查一下就知道是因为github的识别是靠邮箱设置的. 但是如果频繁创建新仓库,容易忘记设定用户名和邮箱. 突发奇想,发现 ...
- day24 03 多继承
day24 03 多继承 正常的代码中 单继承==减少了代码的重复 继承表达的是一种 子类是父类的关系 1.简单的多继承关系 A,B,C,D四个类,其中D类继承A,B,C三个父类,因此也叫多继承,子 ...
- 微信小程序后台获取用户的opeid
1.微信小程序后台获取登录用户的openid,首先微信小程序将code传给后台服务器 wx.login({ success: function (res) { var code = res.code ...
- vscode----vue中HTML代码tab键自动补全
1.在vscode中插件下载并重新加载HTML Snippets 2.settings.json中配置files.associations对象. 找到setting.json文件:文件 --> ...
- 【USACO2009 Open】滑雪课程ski
[USACO2009 Open]滑雪课程 Ski Lessons Time Limit: 1000 ms Memory Limit: 131072 KBytes Description 约翰请贝西去科 ...
- [转]我是蒟蒻,但我有我的OI信仰
我想最大的浪漫莫过于有人陪你征战OI吧 有多少无眠的夜晚?我总是在想, 到底是为了什么? 为了自招?为了省队?为了签约? 这条路很艰难,不可谓不凶险, 当你第一次踏上复试, 你肯定有看到过那些很厉害很 ...
- 1、Web MVC简介