【BZOJ4553】【TJOI2016】【HEOI2016】序列
cdq和整体二分之间的关系好迷啊
原题:
佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他。玩具上有一个数列,数列中某些项的值
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int rd(){int z=,mk=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mk=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mk;
}
struct dcd{int x,y,z,id;}a[];
int n,m,b[];
int id[],mx[],mn[];
int f[];
dcd q[];
int ans[];
int e[],lbt[];
void gtlbt(){ for(int i=;i<=n;++i) lbt[i]=i&-i;}
//void mdf(int x,int y){ while(x<=n) e[x]+=y,x+=lbt[x];}
//int qr(int x){ int bwl=0; while(x) bwl+=e[x],x-=lbt[x]; return bwl;}
void mdf(int x,int y){ while(x<=n) e[x]=max(e[x],y),x+=lbt[x];}
void dlt(int x){ while(x<=n) e[x]=,x+=lbt[x];}
int qr(int x){ int bwl=; while(x) bwl=max(bwl,e[x]),x-=lbt[x]; return bwl;}
/*void bnr(int l,int r){
if(l==r) return ;
int md=(l+r)>>1;
*for(int i=l;i<=r;++i){
if(a[i].y>=md) ans[a[i].id]+=qr(a[i].x);
if(a[i].x<=md) mdf(a[i].z,1);
}*
//cout<<md<<endl;
memset(e,0,sizeof(e));
for(int i=l;i<=r;++i){
//cout<<l<<" "<<r<<" "<<a[i].y<<" "<<a[i].x<<" "<<a[i].z<<endl;
if(a[i].y>=md) f[a[i].id]=max(f[a[i].id],qr(a[i].x)+1);
if(a[i].x<=md) mdf(a[i].z,f[a[i].id]);
}
//for(int i=l;i<=r;++i)if(a[i].x<=md) mdf(a[i].z,-1);
int t1=l,t2=md+1;
for(int i=l;i<=r;++i) q[(a[i].y<=md?t1:t2)++]=a[i];
for(int i=l;i<=r;++i) q[i]=q[i];
bnr(l,md),bnr(md+1,r);
}*/
bool cmp1(dcd x,dcd y){ return x.x<y.x;}
bool cmp2(dcd x,dcd y){ return x.y<y.y;}
bool cmp3(dcd x,dcd y){ return x.id<y.id;}
void cdq(int l,int r){
if(l==r) return ;
int md=(l+r)>>;
cdq(l,md);
sort(a+l,a+md+,cmp1),sort(a+md+,a+r+,cmp2);
//memset(e,0,sizeof(e));
int j=md+;
for(int i=l;i<=md;++i){
while(j<=r && a[j].y<a[i].x) ans[a[j].id]=max(ans[a[j].id],qr(a[j].x)+),++j;
mdf(a[i].z,ans[a[i].id]);
}
while(j<=r) ans[a[j].id]=max(ans[a[j].id],qr(a[j].x)+),++j;
for(int i=l;i<=md;++i) dlt(a[i].z);
sort(a+md+,a+r+,cmp3);
cdq(md+,r);
}
int main(){
//freopen("ddd.in","r",stdin);
//freopen("heoi2016_seq.in","r",stdin);
//freopen("heoi2016_seq.out","w",stdout);
memset(f,,sizeof(f));
cin>>n>>m;
gtlbt();
for(int i=;i<=n;++i) mx[i]=mn[i]=b[i]=rd();
int l,r;
while(m--){
l=rd(),r=rd();
mx[l]=max(mx[l],r),mn[l]=min(mn[l],r);
}
for(int i=;i<=n;++i) a[i].id=i,a[i].x=b[i],a[i].y=mn[i],a[i].z=mx[i],ans[i]=;
cdq(,n);
int mxx=;
for(int i=;i<=n;++i) mxx=max(mxx,ans[i]);
cout<<mxx<<endl;
return ;
}
【BZOJ4553】【TJOI2016】【HEOI2016】序列的更多相关文章
- [BZOJ4553][TJOI2016&&HEOI2016]序列(CDQ分治)
4553: [Tjoi2016&Heoi2016]序列 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1202 Solved: 554[Su ...
- [BZOJ4553][Tjoi2016&Heoi2016]序列 cdp分治+dp
4553: [Tjoi2016&Heoi2016]序列 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 260 Solved: 133[Sub ...
- bzoj4553 [Tjoi2016&Heoi2016]序列 树状数组(区间最大值)+cqd
[Tjoi2016&Heoi2016]序列 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1006 Solved: 464[Submit][ ...
- BZOJ4553: [Tjoi2016&Heoi2016]序列
Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值 可能会变化,但同一个时刻最多只有一个值发生变化.现在佳媛姐姐已经研究出了所 ...
- BZOJ4553: [Tjoi2016&Heoi2016]序列 树套树优化DP
把pos[i]上出现的平常值定义为nor[i]最大值定义为max[i]最小值定义为min[i],那么我们发现在两个值,i(前),j(后),当且仅当max[i]<=nor[j],nor[i]< ...
- 【BZOJ4553】[Tjoi2016&Heoi2016]序列 cdq分治+树状数组
[BZOJ4553][Tjoi2016&Heoi2016]序列 Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值可能 ...
- BZOJ 4553 Tjoi2016&Heoi2016 序列
Tjoi2016&Heoi2016序列 Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值 可能会变化,但同一个时刻最 ...
- 4553: [Tjoi2016&Heoi2016]序列
4553: [Tjoi2016&Heoi2016]序列 链接 分析: 注意所有m此操作中,只会发生一个,于是考虑dp.dp[i]=dp[j]+1,j<i,a[j]<=L[i],R[ ...
- 【50.40%】【BZOJ 4553】[Tjoi2016&Heoi2016]序列
Time Limit: 20 Sec Memory Limit: 128 MB Submit: 371 Solved: 187 [Submit][Status][Discuss] Descript ...
- BZOJ 4553 [Tjoi2016&Heoi2016]序列 ——CDQ分治 树状数组
考虑答案的构成,发现是一个有限制条件的偏序问题. 然后三个维度的DP,可以排序.CDQ.树状数组各解决一维. #include <map> #include <cmath> # ...
随机推荐
- Animation(动画)倒着播放方法
public GameObject AnimationObj;//带有动画的对象 // Use this for initialization void Start () { AnimationObj ...
- OO作业总结(三)
类规格设计 由于没能找到关于类规格设计的发展历史,所以结合程序设计思想的发展来谈谈规格化设计. 最早的程序设计都是采用机器语言来编写的,直接使用二进制码来表示机器能够识别和执行的指令和数 据.简单来说 ...
- iOS 统一配置
1 .统一设置nav标题样式: - (void)_setNavigationTitle { NSDictionary *navigationParams = @{NSForegroundColorAt ...
- Linux命令----su(切换用户)以及passwd(修改用户密码)
一.su命令登录root 用户在使用telnet命令可以远程登录,但不可以登录root,这样就需要使用su命令来登录root用户. telnet登录(不能登录root)--- 1.启动终端 输入 te ...
- Buffer与Cache区别 简要说明
Buffer – 缓冲区 写 用户写入数据存储区域 解决写入冲突 CPU-Memoury-Disk Cache – 缓存区 读 用户读取缓存数据使用 临时存储 Disk-memo ...
- SQL-26 (二次分组)汇总各个部门当前员工的title类型的分配数目,结果给出部门编号dept_no、dept_name、其当前员工所有的title以及该类型title对应的数目count
题目描述 汇总各个部门当前员工的title类型的分配数目,结果给出部门编号dept_no.dept_name.其当前员工所有的title以及该类型title对应的数目countCREATE TABLE ...
- 福大软工 · BETA 版冲刺前准备之拖鞋旅游队
拖鞋旅游队BETA 版冲刺前准备 前言 队名:拖鞋旅游队 组长博客:https://www.cnblogs.com/Sulumer/p/10083834.html 本次作业:https://edu.c ...
- day 43 数据库的密码的的更改如何操作
day 43 数据库的密码的的更改如何操作 步骤: 1 首先看环境变量有没有配好 方法 查看计算机 高级系统设置 2 以上步骤完成后 运行 services 找到 mysql的停止 在启动 3,运行 ...
- day 36 关于io模型的问题 阻塞 和多路复用
# from gevent import spawn,monkey;monkey.patch_all()# from socket import *# def server(ip,port):# se ...
- python scrapy解码方法和时间格式转换
import scrapy from datetime import datetime class BianSpider(scrapy.Spider): name = 'bian' # allowed ...