CF877F题解
题目大意
有一个序列,每个位置上有 \(1\) 或 \(2\) 两种元素若干,每次询问一个区间,求这个区间有多少个子区间满足 \(1\) 类元素恰好比 \(2\) 类元素多 \(k\) 个。
莫队
要是看到很难维护的东西,又允许离线,多半就是莫队。(雾)
来看看一个区间在满足条件的情况有啥可以用到的东西:
\]
\(s1[i]\) 表示从 \(1\) 到 \(i\) 有多少个一类元素,\(s2\) 同理。
移项:
\]
转化成了这样一个问题:
\]
其中 \(val[i]\) 表示 \(s1[i] - s2[i]\)。
首先我们在莫队的过程中维护一个桶,表示目前区间中有多少个 \(val[i]\)。
在莫队的转移过程中,我们得考虑新加入的元素是在左侧还是在右侧。
如果在左侧,\(ans+=Bucket[val[i]+k]\)(因为区间的右侧要比自己大);如果在右侧,则 \(ans+=Bucket[val[i]-k]\)。
关于如何维护桶,离散化就行了。
记得离散化的数组不仅要加入 \(val[i],val[i]+k\) 和 \(val[i]-k\),还要加入 \(0,k\) 和 \(-k\)。(因为 \(val[0]=0\))
code:
#include<algorithm>
#include<cstdio>
#include<cmath>
const int M=1e5+5;
typedef long long ll;
int len;ll lsh[M*3];
int n,m,k,p,t[M],v[M],nxt[M],pre[M];ll CB[M*3];ll now,val[M],ans[M];
struct Query{
int L,R,p,id;
inline bool operator<(const Query&it)const{
return p==it.p?p&1?R<it.R:R>it.R:L<it.L;
}
}q[M];
inline void Add(const int&id,const int&to){
now+=CB[to];++CB[v[id]];
}
inline void Del(const int&id,const int&to){
--CB[v[id]];now-=CB[to];
}
signed main(){
register int i,L=1,R=0;
scanf("%d%d",&n,&k);lsh[++len]=0;lsh[++len]=k;lsh[++len]=-k;
for(i=1;i<=n;++i)scanf("%d",t+i);
for(i=1;i<=n;++i){
scanf("%lld",val+i);
if(t[i]==1)val[i]=val[i-1]+val[i];
else val[i]=val[i-1]-val[i];
lsh[++len]=val[i];lsh[++len]=val[i]-k;lsh[++len]=val[i]+k;
}
std::sort(lsh+1,lsh+len+1);len=std::unique(lsh+1,lsh+len+1)-lsh-1;
for(i=0;i<=n;++i){
v[i]=std::lower_bound(lsh+1,lsh+len+1,val[i])-lsh;
pre[i]=std::lower_bound(lsh+1,lsh+len+1,val[i]-k)-lsh;
nxt[i]=std::lower_bound(lsh+1,lsh+len+1,val[i]+k)-lsh;
}
scanf("%d",&m);p=ceil(n/sqrt(m*2.0/3));
for(i=1;i<=m;++i){
scanf("%d%d",&q[i].L,&q[i].R);--q[i].L;
q[i].id=i;q[i].p=q[i].L/p;
}
std::sort(q+1,q+m+1);
for(i=1;i<=m;++i){
const int&QL=q[i].L,&QR=q[i].R;
while(R<QR)++R,Add(R,pre[R]);
while(L>QL)--L,Add(L,nxt[L]);
while(L<QL)Del(L,nxt[L]),++L;
while(R>QR)Del(R,pre[R]),--R;
ans[q[i].id]=now;
}
for(i=1;i<=m;++i)printf("%lld\n",ans[i]);
}
CF877F题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- Hibernate与JDBC事务整合
一般大家都会使用Spring声明型事务 transactionAttributes 为 PROPAGATION_REQUIRED Hibernate 使用 HibernateTransactionMa ...
- 强化学习中REIINFORCE算法和AC算法在算法理论和实际代码设计中的区别
背景就不介绍了,REINFORCE算法和AC算法是强化学习中基于策略这类的基础算法,这两个算法的算法描述(伪代码)参见Sutton的reinforcement introduction(2nd). A ...
- 手把手带你安装最小化suse 12 linux
当然. 你需要现有一个vmware,还要有一个suse的镜像,suse镜像可以直接去官网获取,只需要注册一个suse的账号就可以了,官网下载会有点慢,可以使用迅雷下载 F2 可以设置安装界面的语言,可 ...
- Linux CentOS 搭建SVN并用钩子自动实现同步到Web目录
linux安装配置SVN并设置钩子 安装说明 系统环境:CentOS-6.3安装方式:yum install (源码安装容易产生版本兼容的问题)安装软件:系统自动下载SVN软件 检查已安装版本 # ...
- MyBatis功能点二:从责任链设计模式的角度理解插件实现技术
MyBatis允许对其四大组件(Executor,StatementHandler,ParameterHandler, ResultSetHandler)进行增强处理.在创建四大组件对象的时候 1.每 ...
- 解决Chrome94之后非安全网站请求localhost报CORS问题
问题 自从谷歌浏览器升级到chrome94版本后,在非安全网站下通过请求本地接口就会出现以下错误: Access to XMLHttpRequest at 'http://127.0.0.1:1000 ...
- 使用.rmp文件在redhat7.9安装oracle19c
19c开始,oracle提供了rmp安装包.感觉安装更方便一些了.记录一次测试环境安装. 1,创建交换空间 2,下载oracle 19c必要文件(oracle官网下载需要注册帐号,可以用迅雷下载后再上 ...
- 乘风破浪,遇见未来元宇宙(Metaverse)之进入元宇宙世界,虚拟数字人行业洞察报告
正值元宇宙热潮,虚拟数字人兴起 作为⼀个新兴领域,虚拟数字⼈已经引起市场和资本的⾼度关注,截⾄目前据不完全统计,全球范围已有500+虚拟数字人相关项目获得融资,融资总额超10亿美元,并且融资项目和总额 ...
- IPC$管道的利用与远程控制
实验目的 通过实验了解IPC$攻击的原理与方法. 实验原理 IPC$攻击的相关原理 IPC$(Internet Process Connection)是共享"命名管道"的资源,它是为了让进程间通信而开 ...
- 这款智能又高效的自助式BI工具,你应该了解一下
如今,企业的经营面临越来越激烈的竞争,如何将数据的价值发挥到最大化,成为众多企业急需解决的问题.如果部署数据分析平台还像以前那样要经历漫长实施过程的话,那么数据化运营将成为空谈.在市场需求的催化下,& ...