P4093 [HEOI2016/TJOI2016]序列

题目描述

佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他。玩具上有一个数列,数列中某些项的值可能会变化,但同一个时刻最多只有一个值发生变化。现在佳媛姐姐已经研究出了所有变化的可能性,她想请教你,能否选出一个子序列,使得在任意一种变化中,这个子序列都是不降的?请你告诉她这个子序列的最长长度即可 。

注意:每种变化最多只有一个值发生变化。在样例输入1中,所有的变化是:

1 2 3
2 2 3
1 3 3
1 1 3
1 2 4

输入输出格式

输入格式:

输入的第一行有两个正整数\(n\),\(m\),分别表示序列的长度和变化的个数。接下来一行有\(n\)个数,表示这个数列原始的状态。接下来\(m\)行,每行有2个数\(x\),\(y\),表示数列的第\(x\)项可以变化成\(y\)这个值。\(1 \le x \le n\)。

输出格式:

输出一个整数,表示对应的答案

说明

对于\(20\%\)数据所有数字均为正整数,且小于等于\(300\)

对于\(50\%\)数据所有数字均为正整数,且小于等于\(3,000\)

对于\(100\%\)数据所有数字均为正整数,且小于等于\(100,000\)


窝太菜了,\(dp\)想复杂了...

一开始一直想着是只能改一个还要取最坏情况,我不可能在\(dp\)状态里面存着这些奇怪的是否取了还能取到最差结果啊。

然而重点在于取最坏情况的任意性...

令\(mx_i,mi_i.now_i\)分别为位置\(i\)的可取最大,最小和当前值。

则可以转移\(dp_i=\max dp_j+1(mx_j\le now_i \&\& now_j\le mi_i)\)

后面的偏序条件可以树套树维护,这里采用CDQ分治

有一些注意点

  • 先做左边,然后处理左对右的贡献,然后做右边
  • 处理完贡献要把右边的顺序还原

Code:

#include <cstdio>
#include <algorithm>
const int N=1e5+10;
struct node
{
int mi,mx,now,id;
}q[N],sq[N];
bool cmp1(node n1,node n2){return n1.mx<n2.mx;}
bool cmp2(node n1,node n2){return n1.now<n2.now;}
int s[N],n,m,ans[N];
int max(int x,int y){return x>y?x:y;}
int min(int x,int y){return x<y?x:y;}
void add(int x,int d){while(x<=N)s[x]=max(s[x],d),x+=x&-x;}
void Clear(int x){while(x<=N)s[x]=0,x+=x&-x;}
int ask(int x){int mx=0;while(x)mx=max(mx,s[x]),x-=x&-x;return mx;}
void CDQ(int l,int r)
{
if(l==r) {ans[q[l].id]=max(ans[q[l].id],1);return;}
int mid=l+r>>1;
CDQ(l,mid);
for(int i=mid+1;i<=r;i++) sq[i]=q[i];
std::sort(q+l,q+mid+1,cmp1);std::sort(q+mid+1,q+r+1,cmp2);
int lp=l,rp=mid+1;
while(lp<=mid&&rp<=r)
{
if(q[lp].mx<=q[rp].now)
add(q[lp].now,ans[q[lp].id]),++lp;
else
ans[q[rp].id]=max(ans[q[rp].id],ask(q[rp].mi)+1),++rp;
}
while(rp<=r) ans[q[rp].id]=max(ans[q[rp].id],ask(q[rp].mi)+1),++rp;
for(int i=l;i<lp;i++) Clear(q[i].now);
for(int i=mid+1;i<=r;i++) q[i]=sq[i];
CDQ(mid+1,r);
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%d",&q[i].now),q[i].mx=q[i].mi=q[i].now,q[i].id=i;
for(int a,b,i=1;i<=m;i++)
{
scanf("%d%d",&a,&b);
q[a].mi=min(q[a].mi,b);
q[a].mx=max(q[a].mx,b);
}
CDQ(1,n);
int mx=0;
for(int i=1;i<=n;i++) mx=max(mx,ans[i]);
printf("%d\n",mx);
return 0;
}

2018.11.27

洛谷 P4093 [HEOI2016/TJOI2016]序列 解题报告的更多相关文章

  1. 洛谷 P4093 [HEOI2016/TJOI2016]序列 CDQ分治优化DP

    洛谷 P4093 [HEOI2016/TJOI2016]序列 CDQ分治优化DP 题目描述 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他. 玩具上有一个数列,数列中某些项的值可能会 ...

  2. BZOJ4553/洛谷P4093 [HEOI2016/TJOI2016]序列 动态规划 分治

    原文链接http://www.cnblogs.com/zhouzhendong/p/8672434.html 题目传送门 - BZOJ4553 题目传送门 - 洛谷P4093 题解 设$Li$表示第$ ...

  3. 洛谷 P2824 [HEOI2016/TJOI2016]排序 解题报告

    P2824 [HEOI2016/TJOI2016]排序 题意: 有一个长度为\(n\)的1-n的排列\(m\)次操作 \((0,l,r)\)表示序列从\(l\)到\(r\)降序 \((1,l,r)\) ...

  4. 洛谷 P4091 [HEOI2016/TJOI2016]求和 解题报告

    P4091 [HEOI2016/TJOI2016]求和 题目描述 在2016年,佳媛姐姐刚刚学习了第二类斯特林数,非常开心. 现在他想计算这样一个函数的值: \[ f(n)=\sum_{i=0}^n\ ...

  5. 洛谷P4093 [HEOI2016/TJOI2016]序列

    题目描述 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值可能会变化,但同一个时刻最多只有一个值发生变化.现在佳媛姐姐已经研究出了所有变化的可能性, ...

  6. 洛谷 P4093 [HEOI2016/TJOI2016]序列(Cdq+dp)

    题面 luogu 题解 \(Cdq分治+dp\) \(mx[i],mn[i]\)分别表示第\(i\)位最大,最小能取到多少 那么有 \(j < i\) \(mx[j] \le a[i]\) \( ...

  7. 洛谷 P2659 美丽的序列 解题报告

    P2659 美丽的序列 题目背景 GD是一个热衷于寻求美好事物的人,一天他拿到了一个美丽的序列. 题目描述 为了研究这个序列的美丽程度,GD定义了一个序列的"美丽度"和" ...

  8. 洛谷 P2501 [HAOI2006]数字序列 解题报告

    P2501 [HAOI2006]数字序列 题目描述 现在我们有一个长度为n的整数序列A.但是它太不好看了,于是我们希望把它变成一个单调严格上升的序列.但是不希望改变过多的数,也不希望改变的幅度太大. ...

  9. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

随机推荐

  1. html5新特性localStorage和sessionStorage

    HTML5 提供了两种在客户端存储数据的新方法: localStorage: (1)它的生命周期是永久的,关闭页面或浏览器之后localStorage中的数据也不会消失. (2)它的容量大小是5M作用 ...

  2. 【PMP考试专栏】01、五大过程组和十大知识领域

  3. Visionpro学习网

    重码网是一个在线机器视觉学习网站,推出了Halcon,Visionpro机器视觉学习视频教程,视频内容通俗易懂,没有编程基础的同学,照着视频练习,也同样可以学会. 学机器视觉,拿高薪,成就技术大拿.重 ...

  4. [转]C#学习笔记15——C#多线程编程

    一.基本概念进程:当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的.线程:线程是程序中的一个执行流,每个线程都有自己的专有寄存 ...

  5. 使用JSon实现三级联动

    JSon实现三级联动 我觉得我这个方法比较麻烦,但是目前技术还比较弱,所以先做个笔记自己理解.目前没有和后台交互,只是在前台页面实现了 jQuery和JSon数据实现的,代码如下: <!DOCT ...

  6. (一)java数据类型图

    ┏数值型━┳━整数型:byte short int long               ┏基本数据类型━━┫              ┗━浮点型:float double              ...

  7. DWZ-JUI+UEditor第二次不显示,UEditor异步加载第二次不显示的解决方案

    使用UEditor-1.4.3中遇到第一次跳转到使用UEditor的界面后,编辑器加载正常,返回后第二次再跳转到这个界面就出现UEditor无法正常加载, 也没百度到答案,看UEditor源码,发现这 ...

  8. IDEA设置头注释—自定义author和date

    IDEA设置头注释,自定义author和date的方法如下所示: 去掉波浪线的方式:鼠标选中单词 --> 点击鼠标右键 --> spelling --> save 'xxx' to ...

  9. AdminLTE 框架应用(一 )- 插件介绍

    原AdminLTE中的插件让我大部分都移除了,第一是占地方,需要的时候再引入也不迟,第二就是有些插件已经过时了,有比较好的插件可以替代.附上项目插件截图 1.bootstrap-addTabs 提供多 ...

  10. hibernate.cfg.xml案例

    一.概念. hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库.既然学习Hibernate那么第 ...