hdu_5324_Boring Class(cdq分治+树状数组)
题意:
给出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分治+树状数组)的更多相关文章
- 【BZOJ4553】[Tjoi2016&Heoi2016]序列 cdq分治+树状数组
[BZOJ4553][Tjoi2016&Heoi2016]序列 Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值可能 ...
- BZOJ 1176 Mokia CDQ分治+树状数组
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- 【bzoj3262】陌上花开 CDQ分治+树状数组
题目描述 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当且仅当Sa&g ...
- 【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 ...
- BZOJ 2683 简单题 cdq分治+树状数组
题意:链接 **方法:**cdq分治+树状数组 解析: 首先对于这道题,看了范围之后.二维的数据结构是显然不能过的.于是我们可能会考虑把一维排序之后还有一位上数据结构什么的,然而cdq分治却可以非常好 ...
- LOJ3146 APIO2019路灯(cdq分治+树状数组)
每个时刻都形成若干段满足段内任意两点可达.将其视为若干正方形.则查询相当于求历史上某点被正方形包含的时刻数量.并且注意到每个时刻只有O(1)个正方形出现或消失,那么求出每个矩形的出现时间和消失时间,就 ...
- BZOJ 4553 [Tjoi2016&Heoi2016]序列 ——CDQ分治 树状数组
考虑答案的构成,发现是一个有限制条件的偏序问题. 然后三个维度的DP,可以排序.CDQ.树状数组各解决一维. #include <map> #include <cmath> # ...
- BZOJ1176---[Balkan2007]Mokia (CDQ分治 + 树状数组)
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1176 CDQ第一题,warush了好久.. CDQ分治推荐论文: 1 <从<C ...
- Hdu4742-Pinball Game 3D(cdq分治+树状数组)
Problem Description RD is a smart boy and excel in pinball game. However, playing common 2D pinball ...
随机推荐
- D3.js:动态效果
D3 提供了 4 个方法用于实现图形的过渡: - transition() 启动过渡效果,其前后是图形变化前后的状态(形状.位置.颜色等等),例如: .attr("fill",&q ...
- JS 用角度换东南西北
最近因为业务,正好需要用设备回传的角度值转成用户读得懂的文字形式 function toDirStr(num){ var num=parseInt(num) var N='北'; var E='东'; ...
- Url Rewrite IIS 配置
在configuration节点下 <system.webServer> <rewrite> <rules> <rule name="rD" ...
- Ubuntu 14.04 登陆界面循环问题解决
今天手贱startx然后虚拟机就卡死了,再开输过密码就无限跳到登陆界面,其他账户可用.怀疑/home未挂载. 解决方法:(alf改成你的用户名) $ cd ~$ sudo chown alf:alf. ...
- MAC OS 常用软件及开发工具
1.各个版本的 Mac OS 链接: http://pan.baidu.com/s/1mgDtCi0 密码: 4y3u 2.Xcode xcode_4.6.3 链接: http://pan.baidu ...
- CODE[VS]-蛇形矩阵-模拟-天梯白银
题目描述 Description 小明玩一个数字游戏,取个n行n列数字矩阵(其中n为不超过100的奇数),数字的填补方法为:在矩阵中心从1开始以逆时针方向绕行,逐圈扩大,直到n行n列填满数字,请输出该 ...
- eclipse中debug快捷方式
eclipse中如何跳转到指定行 :ctrl+L 然后输入行数 F5:跳入方法 F6:向下逐行调试 F7:跳出方法 F8:直接跳转到下一个断点 持续更新
- Defraggler(磁盘整理软件) V2.21.993 绿色版
软件名称: Defraggler(磁盘整理软件) 软件语言: 简体中文 授权方式: 免费软件 运行环境: Win 32位/64位 软件大小: 5.0MB 图片预览: 软件简介: Defraggler ...
- form -转载于blfshiye
Form API 表单API 文件夹 1.概述 2.亮点 3.使用方法 4.表单元素 4.1 基本表单元素 4.2 定制表单元素 5.经常使用函数 5.1 add_action_buttons($c ...
- jquery 操作listbox 左右相互选择
实现左右两个listbox的相互选择功能 代码如下: function ListBox_Move(listfrom, listto) { var size = $j("#" + l ...