题目链接:hdu_5324_Boring Class

题意:

给出n个二维点对,求LIS长度和编号字典序最小的LIS(x非增,y非减)

题解:

dp[i]=max(dp[j]) (i>j,l[i]>=l[j],r[i]<=r[i])

一看就是三维偏序问题。

如果树套树写的好,空间开的大的话,一样可以过,不过这里还是用cdq分治套树状数组好写一点。

用lowbit来维护dp[j]的最大值,然后因为要字典序最小,所以从后往前dp。

 #include<bits/stdc++.h>
#define F(i,a,b) for(int i=a;i<=b;i++)
using namespace std; const int N=1e5+; int n,dp[N],hsh[N],ed,pre[N]; struct BIT
{
int val,idx;
BIT(){val=,idx=N;}
}bit[N],tp; inline void up(BIT &a,BIT b){if(a.val<b.val||a.val==b.val&&a.idx>b.idx)a=b;}
inline void add(int x,BIT c){while(x<=n)up(bit[x],c),x+=x&-x;}
inline void clr(int x){while(x<=n)bit[x].val=,bit[x].idx=N,x+=x&-x;}
inline BIT ask(int x){BIT ans;while(x)up(ans,bit[x]),x-=x&-x;return ans;} struct node
{
int x,y,idx;
bool operator<(const node & b)const
{
if(y!=b.y)return y<b.y;
if(x!=b.x)return x>b.x;
return idx<b.idx;
}
}a[N],tmp[N]; void cdq(int l,int r)
{
if(l==r)return;
int m=l+r>>;
cdq(m+,r);
F(i,l,r)tmp[i]=a[i];
sort(tmp+l,tmp+m+);
sort(tmp+m+,tmp+r+);
int j=r;
for(int i=m;i>=l;i--)
{
for(;j>m&&tmp[j].y>=tmp[i].y;j--)
{
tp.val=dp[tmp[j].idx],tp.idx=tmp[j].idx;
add(tmp[j].x,tp);
}
BIT an=ask(tmp[i].x);
if(dp[tmp[i].idx]<an.val+)dp[tmp[i].idx]=an.val+,pre[tmp[i].idx]=an.idx;
else if(dp[tmp[i].idx]==an.val+)pre[tmp[i].idx]=min(pre[tmp[i].idx],an.idx);
}
F(i,m+,r)clr(tmp[i].x);
cdq(l,m);
} int main()
{
while(~scanf("%d",&n))
{
F(i,,n)scanf("%d",&a[i].x),a[i].idx=i,dp[i]=,pre[i]=N;
F(i,,n)scanf("%d",&a[i].y);
F(i,,n)hsh[i]=a[i].x;
sort(hsh+,hsh++n),ed=unique(hsh+,hsh++n)-hsh;
F(i,,n)a[i].x=lower_bound(hsh+,hsh++ed,a[i].x)-hsh;
F(i,,n)hsh[i]=a[i].y;
sort(hsh+,hsh++n),ed=unique(hsh+,hsh++n)-hsh;
F(i,,n)a[i].y=lower_bound(hsh+,hsh++ed,a[i].y)-hsh;
cdq(,n);
int mx=,st;
F(i,,n)mx=max(mx,dp[i]);
F(i,,n)if(mx==dp[i]){st=i;break;}
printf("%d\n",mx);
for(int i=st,cnt=;i<=n;i=pre[i])printf("%d%c",i," \n"[++cnt==mx]);
}
return ;
}

hdu_5324_Boring Class(cdq分治+树状数组)的更多相关文章

  1. 【BZOJ4553】[Tjoi2016&Heoi2016]序列 cdq分治+树状数组

    [BZOJ4553][Tjoi2016&Heoi2016]序列 Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值可能 ...

  2. BZOJ 1176 Mokia CDQ分治+树状数组

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 821[Submit][St ...

  3. 【bzoj3262】陌上花开 CDQ分治+树状数组

    题目描述 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当且仅当Sa&g ...

  4. 【bzoj2225】[Spoj 2371]Another Longest Increasing CDQ分治+树状数组

    题目描述 给定N个数对(xi, yi),求最长上升子序列的长度.上升序列定义为{(xi, yi)}满足对i<j有xi<xj且yi<yj. 样例输入 8 1 3 3 2 1 1 4 5 ...

  5. BZOJ 2683 简单题 cdq分治+树状数组

    题意:链接 **方法:**cdq分治+树状数组 解析: 首先对于这道题,看了范围之后.二维的数据结构是显然不能过的.于是我们可能会考虑把一维排序之后还有一位上数据结构什么的,然而cdq分治却可以非常好 ...

  6. LOJ3146 APIO2019路灯(cdq分治+树状数组)

    每个时刻都形成若干段满足段内任意两点可达.将其视为若干正方形.则查询相当于求历史上某点被正方形包含的时刻数量.并且注意到每个时刻只有O(1)个正方形出现或消失,那么求出每个矩形的出现时间和消失时间,就 ...

  7. BZOJ 4553 [Tjoi2016&Heoi2016]序列 ——CDQ分治 树状数组

    考虑答案的构成,发现是一个有限制条件的偏序问题. 然后三个维度的DP,可以排序.CDQ.树状数组各解决一维. #include <map> #include <cmath> # ...

  8. BZOJ1176---[Balkan2007]Mokia (CDQ分治 + 树状数组)

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1176 CDQ第一题,warush了好久.. CDQ分治推荐论文: 1 <从<C ...

  9. Hdu4742-Pinball Game 3D(cdq分治+树状数组)

    Problem Description RD is a smart boy and excel in pinball game. However, playing common 2D pinball ...

随机推荐

  1. 启动web项目,报内存不足错误的解决方法

    Initialization of bean failed; nested exception is java.lang.OutOfMemoryError: Java heap space 原因: 在 ...

  2. STM32 Keil查看程序占用ROM和RAM

    1. 编译生成的map文件中code , RO ,RW, ZI 表示内容 Code为程序代码部分 RO-data 表示 程序定义的常量const temp; RW-data 表示 已初始化的全局变量 ...

  3. idea svn 更新覆盖了本地代码

    idea  更新svn代码,覆盖了本地代码,还不能ctr+z怎么办? 下图

  4. mysql权限设置

    想要设定权限,必须通过root用户登录: >> grant all privileges on *.* to root@"%" identified by " ...

  5. javaScript设计模式之常用工厂模式

    工厂函数 定义 由一个工厂对象决定创建某一种产品对象类的实例,主要用来创建同一类对象. 使用场景 比如说你是到一个买宠物的店,里面有很多不同的宠物,你只需要说出宠物的名字给店员就行了. // 狗的类 ...

  6. 有关C语言学习的调查

    有关C语言学习的调查 1.Q:你是怎么学习C语言的?(作业,实验,教材,其他),与你的高超技能相比,C语言的学习有什么经验和教训? A:之间在暑假的之后自己有买了一本C PRIME PLUS 来看基本 ...

  7. [MFC美化] Skin++使用详解-使用方法及注意事项

    主要分为以下几个方面: 1.Skin++使用方法 2.使用中注意事项 一. Skin++使用方法 SkinPPWTL.dll.SkinPPWTL.lib.SkinPPWTL.h ,将三个文件及相应皮肤 ...

  8. Java中集合框架体系

    集合的体系结构:     |--Collection(单列集合的根接口)         |--List(子接口):元素是有序的,元素可以重复.因为该集合体系有索引.             |--A ...

  9. hdu1029

    #include<iostream>#include<string.h>using namespace std;int main(){ int n,i; int t; int ...

  10. matlab,xls转换为mat文件

    b=xlsread('iris_data.xls');save iris_data.mat b