[BZOJ4552][Tjoi2016&Heoi2016]排序(二分答案+线段树)
二分答案mid,将>=mid的设为1,<mid的设为0,这样排序就变成了区间修改的操作,维护一下区间和即可
然后询问第q个位置的值,为1说明>=mid,以上
时间复杂度O(nlog2n)
tips: 线段树操作区间[l,r]需满足l<=r,要特判;tag可能为0,要初始化为-1
Code
#include <cstdio>
#include <algorithm>
#include <cstring>
#define N 100010
using namespace std; struct info{int x,l,r;}q[N];
int n,m,A[N],f[N],Ans,Q; inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
} namespace Seg{
#define MID int mid=(l+r)>>1,ls=id<<1,rs=id<<1|1
int tag[N*4];
struct tree{int c[2];}T[N*4];
void pushup(int l,int r,int id){
MID;
T[id].c[0]=T[ls].c[0]+T[rs].c[0];
T[id].c[1]=T[ls].c[1]+T[rs].c[1];
}
void pushdown(int l,int r,int id){
int &tmp=tag[id];
if(tmp==-1)return;
MID;
tag[ls]=tag[rs]=tmp;
T[ls].c[tmp]=mid-l+1,T[ls].c[tmp^1]=0;
T[rs].c[tmp]=r-mid,T[rs].c[tmp^1]=0;
tmp=-1;
}
void build(int l,int r,int id){
if(l==r){
T[id].c[0]=(f[l]==0)?1:0;
T[id].c[1]=T[id].c[0]^1;
return;
}
MID;
build(l,mid,ls),build(mid+1,r,rs);
pushup(l,r,id);
}
int query(int l,int r,int id,int L,int R,int x){
if(L<=l&&r<=R)return T[id].c[x];
pushdown(l,r,id);
MID;
int res=0;
if(L<=mid)res+=query(l,mid,ls,L,R,x);
if(R>mid)res+=query(mid+1,r,rs,L,R,x);
return res;
}
void upd(int l,int r,int id,int L,int R,int x){
if(L<=l&&r<=R){
tag[id]=x;
T[id].c[x]=r-l+1,T[id].c[x^1]=0;
return;
}
pushdown(l,r,id);
MID;
if(L<=mid)upd(l,mid,ls,L,R,x);
if(R>mid)upd(mid+1,r,rs,L,R,x);
pushup(l,r,id);
}
void clr(){memset(tag,-1,sizeof(tag));}
}using namespace Seg; int main(){
n=read(),m=read();
for(int i=1;i<=n;++i)A[i]=read();
for(int i=1;i<=m;++i)q[i].x=read(),q[i].l=read(),q[i].r=read();
Q=read();
for(int l=1,r=n;l<=r;){
int mid=(l+r)>>1;
for(int i=1;i<=n;++i)f[i]=(A[i]>=mid)?1:0;
clr(),build(1,n,1);
for(int i=1;i<=m;++i){
int L=q[i].l,R=q[i].r,x=q[i].x;
int cnt=query(1,n,1,L,R,x);
if(cnt)upd(1,n,1,L,L+cnt-1,x);
if(cnt<(R-L+1))upd(1,n,1,L+cnt,R,x^1);
}
if(query(1,n,1,Q,Q,1)==1) Ans=mid,l=mid+1;
else r=mid-1;
}
printf("%d\n",Ans);
return 0;
}
[BZOJ4552][Tjoi2016&Heoi2016]排序(二分答案+线段树)的更多相关文章
- [BZOJ4552][TJOI2016&&HEOI2016]排序(二分答案+线段树/线段树分裂与合并)
解法一:二分答案+线段树 首先我们知道,对于一个01序列排序,用线段树维护的话可以做到单次排序复杂度仅为log级别. 这道题只有一个询问,所以离线没有意义,而一个询问让我们很自然的想到二分答案.先二分 ...
- bzoj 4552 [Tjoi2016&Heoi2016]排序 (二分答案 线段树)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4552 题意: 给你一个1-n的全排列,m次操作,操作由两种:1.将[l,r]升序排序,2 ...
- BZOJ 4552 [Tjoi2016&Heoi2016]排序 | 二分答案 线段树
题目链接 题面 题目描述 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他.这个难题是这样子的:给出一个1到n的全排列,现在对这 ...
- 【BZOJ4552】【HEOI2016】排序 [二分答案][线段树]
排序 Time Limit: 60 Sec Memory Limit: 256 MB[Submit][Status][Discuss] Description 在2016年,佳媛姐姐喜欢上了数字序列 ...
- [bzoj4552][Tjoi2016&Heoi2016]排序-二分+线段树
Brief Description DZY有一个数列a[1..n],它是1∼n这n个正整数的一个排列. 现在他想支持两种操作: 0, l, r: 将a[l..r]原地升序排序. 1, l, r: 将a ...
- bzoj 4552 [Tjoi2016&Heoi2016]排序——二分答案
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4552 二分答案,把 >= mid 的设成1.< mid 的设成0,之后排序就变成 ...
- 2018.08.01 BZOJ4552: [Tjoi2016&Heoi2016]排序(二分+线段树)
传送门 线段树简单题. 二分答案+线段树排序. 实际上就是二分答案mid" role="presentation" style="position: relat ...
- 【BZOJ4552】[Tjoi2016&Heoi2016]排序 二分+线段树
[BZOJ4552][Tjoi2016&Heoi2016]排序 Description 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题 ...
- bzoj千题计划128:bzoj4552: [Tjoi2016&Heoi2016]排序
http://www.lydsy.com/JudgeOnline/problem.php?id=4552 二分答案 把>=mid 的数看做1,<mid 的数看做0 这样升序.降序排列相当于 ...
- HDU 5649 DZY Loves Sorting(二分答案+线段树/线段树合并+线段树分割)
题意 一个 \(1\) 到 \(n\) 的全排列,\(m\) 种操作,每次将一段区间 \([l,r]\) 按升序或降序排列,求 \(m\) 次操作后的第 \(k\) 位. \(1 \leq n \le ...
随机推荐
- PHP error_log 实际运用
PHP的error_log()函数合理用起来还真方便呢,来看下这个函数: error_log(message,type,destination,headers); 参数 描述 message 必需.规 ...
- Zabbix3.4服务器的搭建--CentOS7
本教程是目前最简单的Zabbix搭建教程.因为不是编译方式,直接用官方的分发包(rpm)安装. 1.前期准备 安装CentOS 7.4系统后.开启网络功能,其他东西均可不装.切记一定不要配置环境.还有 ...
- ZT 设计模式六大原则(4):接口隔离原则
设计模式六大原则(4):接口隔离原则 分类: 设计模式 2012-02-27 08:32 17948人阅读 评论(21) 收藏 举报 设计模式classinterfacecstring框架 定义:客户 ...
- 在自己机器上实现apache的多域名
自己机器上有3个目录,分别是/var/www/html/ /var/www/solaris/ ...
- aop的概念以及 cglib-nodep-2.1_3.jar第三方jia包动态代理使用
引入 cglib-nodep-2.1_3.ja包 cglib产生的代理类是目标类的子类 定义接口,让切面都继承它,方便加入到动态代理方法 的那个类中使用 在SalaryInterceptor类中使用 ...
- ADF中遍历VO中的行数据(Iterator)
在ADF中VO实质上就是一个迭代器, 1.在Application Module的实现类中,直接借助VO实现类和Row的实现类 TestVOImpl organizationUser = (TestV ...
- BZOJ2333:[SCOI2011]棘手的操作(Splay)
Description 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边,连接第x个节点和第y个节点 A1 x v: ...
- 转发forward和重定向redirect的区别
本质区别:转发只发送一次请求,重定向发送两次请求. 转发: request.getRequestDispatcher("/HiServlet").forward(request,r ...
- Arduino 入门之小星星
原理:通过编号映射不同的频率音频信号,配合延时输出,达到演奏音乐和跑马灯的效果. 优酷视频链接:https://v.youku.com/v_show/id_XMzcxODQ4NjA3Mg==.html ...
- 三十、详述使用 IntelliJ IDEA 解决 jar 包冲突的问题
在实际的 Maven 项目开发中,由于项目引入的依赖过多,遇到 jar 冲突算是一个很常见的问题了.在本文中,我们就一起来看看,如何使用 IntelliJ IDEA 解决 jar 包冲突的问题!简单粗 ...