[pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=61560361

向大(hei)佬(e)实力学(di)习(tou)

Description

给定一个序列,初始为空。现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置。每插入一个数字,我们都想知道此时最长上升子序列长度是多少?

Input

第一行一个整数N,表示我们要将1到N插入序列中,接下是N个数字,第k个数字Xk,表示我们将k插入到位置Xk(0<=Xk<=k-1,1<=k<=N)

Output

N行,第i行表示i插入Xi位置后序列的最长上升子序列的长度是多少。

Sample Input

3

0 0 2

Sample Output

1

1

2

HINT

100%的数据 n<=100000

其实这道题算是一道裸题了,拿来练习一下模板。看到这种活动的插入,就能立即想到平衡树。至于最长上升子序列,如果每插入一次就求一次,再优化都要超时。于是我们就找找性质,发现:由于是有序插入,后插入的一定大,那么每插入一个点,以此点结尾的最长上升子序列就不受后面点的干扰。那么在插入完毕后求一次最长上升子序列就可以了。之后的输出需注意要求的是整个数列的答案,还要在小于等于插入数的dp数组中求max。因为这个我又wa了一遍

至于二分优化,其实也算是练手。简单梳理一下,也便自己理解更透彻。要开一个单调栈(?),存两个元素,一个为值,一个为下标。

以 6 2 1 4 3 为例,从左往右扫

6进栈 >6(1)

dp[1]=1;

2比栈顶元素小,要去替换,二分到6,替换>2(2)

dp[2]=1;

1同理>1(3)

dp[3]=1;

4>1,4直接进栈>1(3) 4(4)

dp[4]=dp[3]+1=2;

3二分换4,>1(3) 3(5)

dp[5]=dp[3]+1=2;

最后再for一遍找max,总o(log n)

这道题因为比较特殊,数字不重复,且按序插入,所以直接以数字本身作为下标。

求最长上升子序列还可以用树状数组优化,哪天再遇到这样的题再复习树状数组优化吧!

代码

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std ; const int N=100000+5; int n,x;
struct Node{
Node *ch[2];
int v,r,siz;
int cmp(int x){
return x <= ch[0]->siz ? 0 : 1;
}
}*root,*null,pool[N],*tail=pool;
int c[N],top=0,dp[N]; Node *newnode(){
Node *rt=++tail;
rt->ch[0]=rt->ch[1]=null;
rt->v=rt->r=rt->siz=0;
return rt;
}
void rotate(Node *&nd,int d){
Node *tp=nd->ch[d];
nd->ch[d]=tp->ch[d^1];tp->ch[d^1]=nd;
nd->siz=nd->ch[0]->siz+nd->ch[1]->siz+1;
tp->siz=tp->ch[0]->siz+tp->ch[1]->siz+1;
nd=tp;
}
void insert(Node *&nd,int val,int pos){
if(nd==null){
nd=newnode();
nd->v=val;
nd->siz=1;
nd->r=rand();
return ;
}
int d=nd->cmp(pos);
insert(nd->ch[d],val,d ? pos - nd->ch[0]->siz - 1: pos );
if(nd->ch[d]->r > nd->r ){
rotate(nd,d);
}
nd->siz=nd->ch[0]->siz+nd->ch[1]->siz+1;
}
int get_dp(int x){
int rt;
if(x>c[top]){
c[++top]=x;
return dp[c[top-1]]+1;
}
int le=0,ri=top;
while(le<ri){
int mid=(le+ri)>>1;
if(c[mid]>x) ri=mid;
if(c[mid]<=x) le=mid+1;
}
c[le]=x;
return dp[c[le-1]]+1;
}
void query(Node *nd){
if(nd==null) return ;
query(nd->ch[0]);
dp[nd->v]=get_dp(nd->v);
query(nd->ch[1]);
}
int main(){
srand(23425546);
null=++tail;
null->ch[0]=null->ch[1]=null;
null->v=null->r=null->siz=0;
root=null; scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&x);
insert(root,i,x);
}
query(root);
for(int i=1;i<=n;i++){
dp[i]=max(dp[i-1],dp[i]);
printf("%d\n",dp[i]);
}
return 0;
}

总结:

1、对题的辨析能力还需加强,要多想多观察,找到不被影响的东西

【bzoj3173】【Tjoi2013】【最长上升子序列】treap+dp二分优化的更多相关文章

  1. BZOJ3173 TJOI2013最长上升子序列(Treap+ZKW线段树)

    传送门 Description 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? Input ...

  2. [BZOJ3173][Tjoi2013]最长上升子序列

    [BZOJ3173][Tjoi2013]最长上升子序列 试题描述 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上 ...

  3. BZOJ 3173: [Tjoi2013]最长上升子序列 [splay DP]

    3173: [Tjoi2013]最长上升子序列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1613  Solved: 839[Submit][St ...

  4. bzoj3173[Tjoi2013]最长上升子序列 平衡树+lis

    3173: [Tjoi2013]最长上升子序列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2253  Solved: 1136[Submit][S ...

  5. bzoj3173: [Tjoi2013]最长上升子序列(树状数组+二分倒推)

    3173: [Tjoi2013]最长上升子序列 题目:传送门 题解:  好题! 怎么说吧...是应该扇死自己...看错了两次题: 每次加一个数的时候,如果当前位置有数了,是要加到那个数的前面,而不是直 ...

  6. 【bzoj3173】[Tjoi2013]最长上升子序列 Treap

    题目描述 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? 输入 第一行一个整数N,表示我们要 ...

  7. bzoj千题计划316:bzoj3173: [Tjoi2013]最长上升子序列(二分+树状数组)

    https://www.lydsy.com/JudgeOnline/problem.php?id=3173 插入的数是以递增的顺序插入的 这说明如果倒过来考虑,那么从最后一个插入的开始删除,不会对以某 ...

  8. bzoj3173: [Tjoi2013]最长上升子序列(fhqtreap)

    这题用fhqtreap可以在线. fhqtreap上维护以i结尾的最长上升子序列,数字按从小到大加入, 因为前面的数与新加入的数无关, 后面的数比新加入的数小, 所以新加入的数对原序列其他数的值没有影 ...

  9. BZOJ3173:[TJOI2013]最长上升子序列(Splay)

    Description 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? Input 第一行一 ...

随机推荐

  1. Node rescue/unrescue相关代码流程图

  2. 浅谈传输层协议TCP和UDP

    在当今因特网的层次结构中,传输层的协议主要有两种,其一为Transmission Control Protocol,即TCP:其二为User Datagram Protocol,即UDP. 1.TCP ...

  3. 课时6:Python之常用操作符

    目录: 一.算术操作符 二.优先级问题 三.比较操作符 四.逻辑操作符 五.课时06课后习题及答案 ****************** 一.算术操作符 ****************** > ...

  4. 剑指offer:二维数组中的查找

    目录 题目 解题思路 具体代码 题目 题目链接 剑指offer:二维数组中的查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺 ...

  5. quagga源码学习--BGP协议中的routemap

    路由策略的基础知识 定义 路由策略(Routing Policy)作用于路由,主要实现了路由过滤和路由属性设置等功能,它通过改变路由属性(包括可达性)来改变网络流量所经过的路径. 目的 路由器在发布. ...

  6. MySQL之优化总结

    http://www.cnblogs.com/benshan/archive/2012/07/27/2612212.html MySQL之优化总结    今天,数据库的操作越来越成为整个应用的性能瓶颈 ...

  7. 【bzoj4154】[Ipsc2015]Generating Synergy KD-tree

    题目描述 给定一棵以1为根的有根树,初始所有节点颜色为1,每次将距离节点a不超过l的a的子节点染成c,或询问点a的颜色 输入 第一行一个数T,表示数据组数 接下来每组数据的第一行三个数n,c,q表示结 ...

  8. 【bzoj3675】[Apio2014]序列分割 斜率优化dp

    原文地址:http://www.cnblogs.com/GXZlegend/p/6835179.html 题目描述 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列 ...

  9. [bzoj3218] a+b problem [最小割+数据结构优化建图]

    题面 传送门 思路 最小割 我们首先忽略掉那个奇♂怪的限制,就有一个比较显然的最小割模型: 建立源点$S$和汇点$T$ 对于每个元素$i$建立一个点$i$,连边$<S,i,w[i]>$和$ ...

  10. select下拉框右对齐,去掉箭头,替换箭头

    右对齐 select{ width:auto; direction: rtl; } select option { direction: ltr; } 去掉箭头(不设置背景色会有灰色背景) selec ...