洛谷P4113 [HEOI2012]采花 题解

题目链接:P4113 [HEOI2012]采花

题意:萧薰儿是古国的公主,平时的一大爱好是采花。

今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花。

花园足够大,容纳了 nnn 朵花,共有 ccc 种颜色,用整数 1∼c1 \sim c1∼c 表示。且花是排成一排的,以便于公主采花。公主每次采花后会统计采到的花的颜色数,颜色数越多她会越高兴。同时,她有一癖好,她不允许最后自己采到的花中,某一颜色的花只有一朵。为此,公主每采一朵花,要么此前已采到此颜色的花,要么有相当正确的直觉告诉她,她必能再次采到此颜色的花。

由于时间关系,公主只能走过花园连续的一段进行采花,便让女仆福涵洁安排行程。福涵洁综合各种因素拟定了 mmm 个行程,然后一一向你询问公主能采到的花共有几种不同的颜色。

1≤n,c,m≤2×1061 \leq n, c, m \leq 2 \times 10^61≤n,c,m≤2×106。

对于全部的测试点,保证 1≤xi≤c1 \leq x_i \leq c1≤xi​≤c,1≤l≤r≤n1 \leq l \leq r \leq n1≤l≤r≤n。

其实就是 P1972 [SDOI2009] HH的项链 改了一改,

本题具体的做法是预处理出所有第二次出现的数的贡献,然后离线处理询问。

(作者语文比较烂,不知道这句话放哪里比较好,就放前面来了)

下面是详细的解释。


设数组 val={1,2,2,3,1,1,3}\text{val} = \{1,2,2,3,1,1,3\}val={1,2,2,3,1,1,3}

要询问一个区间 [1,7]={1,2,2,3,1,1,3}[1,7]=\{1,2,2,3,1,1,3\}[1,7]={1,2,2,3,1,1,3}

每个数的贡献是这样的 {0,0,1,0,1,0,1}\{0,0,1,0,1,0,1\}{0,0,1,0,1,0,1}

实际上我们只需要处理第二次出现的数的贡献即可

因为出现两次是容易处理的,并且小于的不会产生贡献,大于的不会增加贡献

不难发现区间询问可以用树状数组维护贡献

一个暴力的想法是,对于每个询问 [l,r][l,r][l,r] ,我们扫一遍 [1,l−1][1,l-1][1,l−1]

为什么要扫一遍呢?因为对于出现大于两次的,

我们只把贡献记在了它第二次出现的位置上,

而这个数可能在 [1,l−1][1,l-1][1,l−1] 和 [l,r][l,r][l,r] 都出现了两次及以上

当然这样暴力扫肯定是不行的,考虑离线处理询问。

把询问按照 lll 从小到大排序,这样我们只要在询问的过程中扫就可以了

时间复杂度 O(mlog⁡n)O(m \log n)O(mlogn)

代码:

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <iomanip>
#include <random>
using namespace std;
// #define int long long
// #define INF 0x3f3f3f3f3f3f3f3f
namespace FastIO
{#define gc() readchar()#define pc(a) putchar(a)#define SIZ (int)(1e6+15)char buf1[SIZ],*p1,*p2;char readchar(){if(p1==p2)p1=buf1,p2=buf1+fread(buf1,1,SIZ,stdin);return p1==p2?EOF:*p1++;}template<typename T>void read(T &k){char ch=gc();T x=0,f=1;while(!isdigit(ch)){if(ch=='-')f=-1;ch=gc();}while(isdigit(ch)){x=(x<<1)+(x<<3)+(ch^48);ch=gc();}k=x*f;}template<typename T>void write(T k){if(k<0){k=-k;pc('-');}static T stk[66];T top=0;do{stk[top++]=k%10,k/=10;}while(k);while(top){pc(stk[--top]+'0');}}
}using namespace FastIO;
#define N (int)(2e6+15)struct node
{int l,r,id;
}q[N];
int n,k,m,b[N],val[N],nx[N],first[N],ans[N];
struct BIT
{int tree[N];int lowbit(int x){return x&(-x);}void add(int x,int v){for(; x<=n; x+=lowbit(x))tree[x]+=v;}int qSum(int x){int res=0;for(; x>=1; x-=lowbit(x))res+=tree[x];return res;}
}tr;
signed main()
{// ios::sync_with_stdio(0);// cin.tie(0);cout.tie(0);// freopen("check.in","r",stdin);// freopen("check.out","w",stdout);read(n);read(k);read(m);for(int i=1; i<=n; i++) read(val[i]);for(int i=n; i>=1; i--){nx[i]=first[val[i]];first[val[i]]=i;}for(int i=1; i<=n; i++)if(++b[val[i]]==2)tr.add(i,1);for(int i=1; i<=m; i++){read(q[i].l);read(q[i].r);q[i].id=i;}sort(q+1,q+1+m,[](node a,node b){return a.l<b.l;});int now=1;for(int i=1; i<=m; i++){for(; now<q[i].l; ++now){if(nx[now])tr.add(nx[now],-1);if(nx[nx[now]])tr.add(nx[nx[now]],1);}ans[q[i].id]=tr.qSum(q[i].r)-tr.qSum(q[i].l);}for(int i=1; i<=m; i++)write(ans[i]),pc('\n');return 0;
}

参考文献

[1] https://www.luogu.com.cn/blog/zykykyk/solution-p4113

转载请说明出处

洛谷P4113 [HEOI2012]采花 题解相关推荐

  1. P4113 [HEOI2012]采花 ( 树状数组 + 离线 )

    题目链接:点击进入 题目 思路 跟此题相似:HH的项链 对于若干个询问的区间 [ l , r ] ,如果他们的 r 都相等的话,那么对于数组中出现的同一个数字,因为要求只有每个数出现至少两次才可以计入 ...

  2. P4113 [HEOI2012]采花

    题目描述 萧薰儿是古国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花. 花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一排的,以便于 ...

  3. P4113 [HEOI2012]采花 【树状数组 AC】【莫队/主席树 TLE】

    传送门 题意简述:给定一个长度为 n 的序列,有 m 次询问,每次询问一段区间,求区间中有多少个数出现次数超过 1 次 这道题真的有点恶心...在洛谷上属于莫队,但是莫队会T,数据居然有2e6.莫队的 ...

  4. P4113 [HEOI2012]采花 树状数组离线

    题意: 询问区间内有多少个出现次数大于等于2次数的种类. n<=2e6 题解: 主要是n<=2e6,不然确实有很多种做法 跟HH的项链一样的思路,发现是离线,想了一会发现好像跟hh的项链一 ...

  5. 洛谷P1462 通往奥格瑞玛的道路 题解

    洛谷P1462 通往奥格瑞玛的道路 题解 题目链接:P1462 通往奥格瑞玛的道路 题意:在艾泽拉斯,有 nnn 个城市.编号为 1,2,3,-,n1,2,3,\ldots,n1,2,3,-,n . ...

  6. [HEOI2012]采花(思维 + 离线 + 树状数组)

    题目链接 分析 我只能说太妙了- 离线 + 树状数组 参考题解: 这个题要和<HH的项链>做对比: 关键就是为什么要离线处理,以及 怎么对区间进行排序和维护: [SDOI2009]HH的项 ...

  7. 洛谷P5365 [SNOI2017] 英雄联盟 题解

    洛谷P5365 [SNOI2017] 英雄联盟 题解 题目链接:P5365 [SNOI2017] 英雄联盟 题意:正在上大学的小皮球热爱英雄联盟这款游戏,而且打的很菜,被网友们戏称为「小学生」. 现在 ...

  8. 1619. [HEOI2012]采花

    1619. [HEOI2012]采花 ★★☆   输入文件:1flower.in   输出文件:1flower.out   简单对比 时间限制:5 s   内存限制:128 MB [题目描述] 萧薰儿 ...

  9. 洛谷P1129 [ZJOI2007] 矩阵游戏 题解

    洛谷P1129 [ZJOI2007] 矩阵游戏 题解 题目链接:P1129 [ZJOI2007] 矩阵游戏 题意:给定一张有黑白棋子的正方形棋盘,问存不存在解法使得经过若干次交换行或列的操作后,左上角 ...

最新文章

  1. mysql报错:Column 'id' in field list is ambiguous,以及tp的三表联合查询语句,打印sql等
  2. 单链表的实现:增删改查
  3. python几乎无所不能 只有你不知道的,如何通过Python玩转小视频
  4. 二元树中和为某一值的所有路径
  5. LINQ to SQL学习的几个问题
  6. 网络工程师需要哪些知识_成长工程师可以教给我们哪些工程知识
  7. 【转】.NET试题总结二
  8. 这两个漏洞暴露 Facebook Group 成员,有个用手机就能发现,获奖$9000
  9. layer + ajax 弹出框
  10. 东南亚电商巨头Shopee宣布裁员,互联网大厂还能养老吗?
  11. 预编译的头文件 pch.h
  12. 未来5年可能必备的IT技术
  13. 【MSSQL】SQL SERVER导入中文乱码问题解决
  14. AJAX for asp.net 插件安装及测试
  15. LeetCode179:最大数
  16. Spring Cloud学习系列第一章:Eureka之服务注册与发现
  17. Symbian OS 开发初级手册(转)
  18. ruby on rails_最终的中级Ruby on Rails教程:让我们创建一个完整的应用程序!
  19. uniapp 打开高德地图或者百度地图 进行导航
  20. 多源BFS 理解学习+代码模板---跟龙之介学算法

热门文章

  1. 化危为机,“戴”你走近“小企业”数字化生存
  2. 抓取淘宝天猫商品详情图
  3. element 合并单元格
  4. 阿里云天池task4
  5. 数学论文(优化方向)写作总结
  6. 在线教育工程结构(二)----在线教育工程结构
  7. leetcode 1737 解题思路及注释code 贪心
  8. ae制作小球轨迹运动_别走,年轻人!这是AE粘性小球制作方法汇总!
  9. 一个程序员眼中的北京和上海
  10. SQL语句:rtrim及ltrim 函数