luogu P4688 [Ynoi2016]掉进兔子洞
我们要求的答案应该是三个区间长度\(-3*\)在三个区间中都出现过的数个数
先考虑数列中没有相同的数怎么做,那就是对三个区间求交,然后交集大小就是要求的那个个数.现在有相同的数,考虑给区间中的数安排位置,即区间中如果出现了多个相同的数\(x\),那么就把第一个\(x\)放在\(x\)这种数要放的第一个位置,把第二个\(x\)放在第二个对应位置,依次类推.具体的,我们用桶维护区间内所有数的出现次数,然后给每种数安排一个初始下标\(ps_x\),使得后面过程中放数不会重叠,如果数\(x\)出现了\(c\)次,那么就把另一个数组内\([ps_x,ps_x+c-1]\)这些位置记为1.那如果把一个询问的三个区间对应的状态数组取交,交集大小即为我们要的都出现过的数个数
求交集显然可以套bitset,然后询问若干区间信息再套个莫队,每次某个询问把三个区间的bitset并在另一个对应的bitset就行了.注意空间可能一次开不下,所以要把询问分成若干组去跑
#include<bits/stdc++.h>
#define LL long long
#define LLL __int128
#define db double
using namespace std;
const int N=1e5+10,qsz=570;
int rd()
{
int x=0,w=1;char ch=0;
while(ch<'0'||ch>'9'){if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
int n,q,t,bl[N],a[N],b[N],cn[N],zq[N>>2],an[N>>2];
bitset<N> bb[N>>2],nb;
struct QR
{
int l,r,i;
bool operator < (const QR &bb) const {return bl[l]!=bl[bb.l]?bl[l]<bl[bb.l]:r<bb.r;}
}qq[N];
int main()
{
n=rd(),q=rd();
for(int i=1;i<=n;++i) bl[i]=i/qsz;
for(int i=1;i<=n;++i) a[i]=b[i]=rd();
sort(b+1,b+n+1),t=unique(b+1,b+n+1)-b-1;
for(int i=1;i<=n;++i)
{
a[i]=lower_bound(b+1,b+t+1,a[i])-b;
++cn[a[i]+1];
}
for(int i=3;i<=t;++i) cn[i]+=cn[i-1];
for(int i=1,j=25000;i<=q;i+=25000,j+=25000)
{
j=min(j,q);
int tq=0;
for(int k=i,o=1;k<=j;++k,++o)
{
zq[o]=an[o]=0;
int l=rd(),r=rd();
an[o]+=r-l+1,qq[++tq]=(QR){l,r,o};
l=rd(),r=rd();
an[o]+=r-l+1,qq[++tq]=(QR){l,r,o};
l=rd(),r=rd();
an[o]+=r-l+1,qq[++tq]=(QR){l,r,o};
}
sort(qq+1,qq+tq+1);
qq[++tq]=(QR){n+1,n,0};
for(int k=1,l=1,r=0;k<=tq;++k)
{
while(r<qq[k].r){++r,++cn[a[r]],nb[cn[a[r]]]=1;}
while(r>qq[k].r){nb[cn[a[r]]]=0,--cn[a[r]],--r;}
while(l<qq[k].l){nb[cn[a[l]]]=0,--cn[a[l]],++l;}
while(l>qq[k].l){--l,++cn[a[l]],nb[cn[a[l]]]=1;}
if(!qq[k].i) continue;
if(!zq[qq[k].i]) bb[qq[k].i]=nb;
else bb[qq[k].i]&=nb;
++zq[qq[k].i];
}
for(int k=i,o=1;k<=j;++k,++o) printf("%d\n",an[o]-3*(int)bb[o].count());
}
return 0;
}
luogu P4688 [Ynoi2016]掉进兔子洞的更多相关文章
- luogu P4688 [Ynoi2016]掉进兔子洞 bitset 莫队
题目链接 luogu P4688 [Ynoi2016]掉进兔子洞 题解 莫队维护bitset区间交个数 代码 // luogu-judger-enable-o2 #include<cmath&g ...
- [Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset)
[Luogu 4688] [Ynoi2016]掉进兔子洞 (莫队+bitset) 题面 一个长为 n 的序列 a.有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间 ...
- p4688 [Ynoi2016]掉进兔子洞
传送门 分析 我们考虑先将所有数离散化 之后我们对于每个状态用一个bitset来记录 其中第i段表示颜色i的信息 对于每一段信息均是段首若干1,剩余若干0表示这种颜色有多少个 于是我们不难想到莫队 答 ...
- [洛谷P4688][Ynoi2016]掉进兔子洞
题目大意:给定一个$n(n\leqslant10^5)$序列,$m(m\leqslant10^5)$个询问,每个询问给出$l_1,r_1,l_2,r_2,l_3,r_3$.令$s$为该三个区间的交集的 ...
- 【洛谷 P4688】 [Ynoi2016]掉进兔子洞(bitset,莫队)
题目链接 第一道Ynoi 显然每次询问的答案为三个区间的长度和减去公共数字个数*3. 如果是公共数字种数的话就能用莫队+bitset存每个区间的状态,然后3个区间按位与就行了. 但现在是个数,bits ...
- [Ynoi2016]掉进兔子洞 题解
题面传送门:https://www.luogu.org/problemnew/show/P4688 (温馨提示,请直接翻至题目描述部分) 1e5的数据范围,以及对区间每个权值出现次数取min此类主席树 ...
- BZOJ.4939.[Ynoi2016]掉进兔子洞(莫队 bitset 分组询问)
BZOJ 洛谷 删掉的数即三个区间数的并,想到bitset:查多个区间的数,想到莫队. 考虑bitset的每一位如何对应每个数的不同出现次数.只要离散化后不去重,每次记录time就可以了. 但是如果对 ...
- BZOJ4939: [Ynoi2016]掉进兔子洞(莫队 bitset)
题意 题目链接 一个长为 n 的序列 a. 有 m 个询问,每次询问三个区间,把三个区间中同时出现的数一个一个删掉,问最后三个区间剩下的数的个数和,询问独立. 注意这里删掉指的是一个一个删,不是把等于 ...
- bzoj千题计划320:bzoj4939: [Ynoi2016]掉进兔子洞(莫队 + bitset)
https://www.lydsy.com/JudgeOnline/problem.php?id=4939 ans= r1-l1+1 + r2-l2+1 +r3-l3+1 - ∑ min(cnt1[i ...
随机推荐
- visible,invisible和GONE的区别
在Android开发中,大部分控件都有visibility这个属性,其属性有3个分别为“visible ”.“invisible”.“gone”.主要用来设置控制控件的显示和隐藏.有些人可能会疑惑In ...
- python之NLP数据清洗
1.知识点 """ 安装模块:bs4 nltk gensim nltk:处理英文 1.安装 2.nltk.download() 下载相应的模块 英文数据处理: 1.去掉h ...
- 手把手教你如何玩转Solr(包含项目实战)
一:Solr简介 Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口.用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引 ...
- R语言 我要如何开始R语言_数据分析师
R语言 我要如何开始R语言_数据分析师 我要如何开始R语言? 很多时候,我们的老板跟我们说,这个东西你用R语言去算吧,Oh,My god!什么是R语言?我要怎么开始呢? 其实回答这个问题很简单,首先, ...
- JAVA 基础编程练习题11 【程序 11 求不重复数字】
11 [程序 11 求不重复数字] 题目:有 1.2.3.4 个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 程序分析:可填在百位.十位.个位的数字都是 1.2.3.4.组成所有的排列后 ...
- 1. hadoop使用启动命令时报错之分析解决
今天在学习hadoop启动命令的时候,先jps看了下,发现namenode.datanode都开着,所以想要先停止这些服务,结果输入命令后报错:“WARN util.NativeCodeLoader: ...
- html5 iphone input 输入法 弹窗将页面顶起 解决办法
给 input 添加失焦事件,然后滚动视图 input.search(type="text",@blur="scrollTop") scrollTop(){ w ...
- SpringCloud学习(SPRINGCLOUD微服务实战)一
SpringCloud学习(SPRINGCLOUD微服务实战) springboot入门 1.配置文件 1.1可以自定义参数并在程序中使用 注解@component @value 例如 若配置文件为a ...
- xss 学习(一)
存储型 .反射型.DOM 型这是最常见的三种分类: 存储型存储型XSS也叫持久型XSS,存储的意思就是Payload是有经过存储的,当一个页面存在存储型XSS的时候,XSS注入成功后,那么每次访问该页 ...
- 【VS开发】【Live555-rtsp】RTSP服务器实例live555源代码分析
原文地址:RTSP服务器实例live555源代码分析作者:mozheer 1. RTSP连接的建立过程 RTSPServer类用于构建一个RTSP服务器,该类同时在其内部定义了一个RTSPClient ...