过了之后感觉曾经真的做过这样的类型的题。

之前一直非常疑惑二级排序的优先级问题,如今发现二级排序真的没有绝对的优先级。

对于此题,若按W排序,则有1到i件物品的W均小于等于第i+1件物品(设为A)的W,那么对于第i+1件我们在[1,i]中要选取一个B,使得B.w < A.w && B.h < A.h 且B.h尽可能的大。

这就是所谓的最接近A的B。

由于对于W,后面的均大于等于前面的,所以我们须要一个尽可能大的H。

Splay_Tree实现。

#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <queue>
#include <cmath>
#include <stack>
#include <string>
#include <map>
#include <ctime> #pragma comment(linker, "/STACK:1024000000");
#define EPS (1e-8)
#define LL long long
#define ULL unsigned long long
#define _LL __int64
#define INF 0x3f3f3f3f
#define Mod 300 using namespace std; struct N
{
//info
int son[2],pre; //data
int w,h;
int ls,rs,s;
int Minw,Minh,Maxh; bool operator <(const N &a) const{
if(w == a.w)
return h < a.h;
return w < a.w;
}
}st[20010],num[20010]; int Top; void Updata(int root)
{
st[root].ls = 0,st[root].rs = 0;
st[root].Minw = st[root].w;
st[root].Minh = st[root].h;
st[root].Maxh = st[root].h; if(st[root].son[0] != -1)
{
st[root].ls = st[st[root].son[0]].s;
st[root].Minw = min(st[root].Minw,st[st[root].son[0]].Minw);
st[root].Minh = min(st[root].Minh,st[st[root].son[0]].Minh);
st[root].Maxh = max(st[root].Maxh,st[st[root].son[0]].Maxh);
} if(st[root].son[1] != -1)
{
st[root].rs = st[st[root].son[1]].s;
st[root].Minw = min(st[root].Minw,st[st[root].son[1]].Minw);
st[root].Minh = min(st[root].Minh,st[st[root].son[1]].Minh);
st[root].Maxh = max(st[root].Maxh,st[st[root].son[1]].Maxh);
} st[root].s = st[root].ls + st[root].rs + 1;
} void Push_Down(int root)
{
;
} void Rotate(int root,int dir)
{
st[st[root].pre].son[dir] = st[root].son[1^dir];
st[root].son[1^dir] = st[root].pre; if(st[st[st[root].pre].pre].son[0] == st[root].pre)
st[st[st[root].pre].pre].son[0] = root;
else
st[st[st[root].pre].pre].son[1] = root;
int temp = st[root].pre;
st[root].pre = st[st[root].pre].pre;
st[temp].pre = root; if(st[temp].son[dir] != -1)
st[st[temp].son[dir]].pre = temp;
Updata(temp);
Updata(root);
} int Splay(int root,int goal)
{
while(st[root].pre != goal)
{
Rotate(root,(st[st[root].pre].son[0] == root ? 0 : 1));
} return root;
} int Search_Site(int root,int site)
{
Push_Down(root); int temp; if(st[root].ls + 1 == site)
temp = root;
else if(st[root].ls + 1 < site)
temp = Search_Site(st[root].son[1],site-st[root].ls-1);
else
temp = Search_Site(st[root].son[0],site); Updata(root);
return temp;
} void Init(int l,int r,int &root,int pre)
{
if(l > r)
return ;
int mid = (l+r)>>1; root = Top++; st[root] = num[mid];
st[root].pre = pre,st[root].son[0] = -1,st[root].son[1] = -1; Init(l,mid-1,st[root].son[0],root);
Init(mid+1,r,st[root].son[1],root); Updata(root);
} void Query(int root,int w,int h,int &anw,int &MaxH)
{
if(root == -1)
return ; if(w <= st[root].w)
{
Query(st[root].son[0],w,h,anw,MaxH);
return ;
} if(st[root].h < h && st[root].h > MaxH)
{
MaxH = st[root].h;
anw = root;
} if(st[root].son[1] != -1 && st[st[root].son[1]].Minw < w && st[st[root].son[1]].Minh < h && st[st[root].son[1]].Maxh > MaxH)
{
Query(st[root].son[1],w,h,anw,MaxH);
} Query(st[root].son[0],w,h,anw,MaxH);
} int main()
{
int T; scanf("%d",&T); int n; int root,i; while(T--)
{
scanf("%d",&n); root = -1; Top = 1;
st[0].son[0] = -1,st[0].son[1] = -1; num[1].w = -1;
num[1].h = -1; num[n+2].w = 1000000000;
num[n+2].h = 1000000000; for(i = 2;i <= n+1; ++i)
scanf("%d %d",&num[i].w,&num[i].h); sort(num+1,num+n+3); Init(1,n+2,root,0); int ans = n; for(i = 2;i <= n+1; ++i)
{
root = Splay(Search_Site(root,st[root].s),0);
root = Splay(Search_Site(root,1),0); int anw = -1,MaxH = -1; Query(st[st[root].son[1]].son[0],num[i].w,num[i].h,anw,MaxH); if(anw == -1)
continue;
ans--; root = Splay(anw,0);
root = Splay(Search_Site(root,st[anw].ls+2),0);
root = Splay(Search_Site(root,st[anw].ls),0); st[st[root].son[1]].son[0] = -1;
Updata(st[root].son[1]);
Updata(root);
} printf("%d\n",ans);
}
return 0;
}

HDU 1677 Nested Dolls的更多相关文章

  1. hdu 1677 Nested Dolls【贪心解嵌套娃娃问题】

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1677 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  2. HDU 1277 Nested Dolls

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1677 题意: 玩俄罗斯套娃,问最后至少还剩几个. 题解: 这题可以和拦截导弹做对比,因为这里是二维的 ...

  3. hdu----(1677)Nested Dolls(DP/LIS(二维))

    Nested Dolls Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tota ...

  4. HDU 1677

    Nested Dolls Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tota ...

  5. Nested Dolls 贪心 + dp

    G: Nested Dolls Time Limit: 1 Sec     Memory Limit: 128 Mb     Submitted: 99     Solved: 19 Descript ...

  6. SPOJ 3943 - Nested Dolls 最长不下降子序列LIS(二分写法)

    现在n(<=20000)个俄罗斯套娃,每个都有宽度wi和高度hi(均小于10000),要求w1<w2并且h1<h2的时候才可以合并,问最少能剩几个. [LIS]乍一看跟[这题]类似, ...

  7. 8.3 LIS LCS LCIS(完结了==!)

    感觉这个专题真不好捉,伤心了,慢慢啃吧,孩纸 地址http://acm.hust.edu.cn/vjudge/contest/view.action?cid=28195#overview 密码  ac ...

  8. POJ3636Nested Dolls[DP LIS]

    Nested Dolls Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8323   Accepted: 2262 Desc ...

  9. LCS,LIS,LCIS

    网站:CSUST 8月3日(LCS,LIS,LCIS) LCS:      以下讲解来自:http://blog.csdn.net/yysdsyl/article/details/4226630 [问 ...

随机推荐

  1. gulp快速入门

    gulp快速入门 因为之前一直有人给我推荐gulp,说他这里好哪里好的.实际上对我来说够用就行.grunt熟悉以后实际上他的配置也不难,说到效率的话如果真是要完整打包上线也不在乎那么几秒时间,对于项目 ...

  2. Linux好书、经典书籍推荐

    Linux好书.经典书籍推荐 思想篇 <Linux/Unix设计思想> 图书将Unix与Linux的原理有效地结合起来,总结了Unix/Linux软件开发中的原则.在保留了第1版中Unix ...

  3. 微通道对接ERP、CRM、OA、HR、SCM、PLM和其他管理系统解决方案

    公司现有ERP.CRM.OA.HR.SCM.PLM等管理系统的对接微信公共平台服务 方法1:开放接口 企业开放现有系统数据接口给第三方,或由第三方开发数据接口对接微信公众平台 方法2:获取数据库 企业 ...

  4. 如何在WindowsPhone Bing Map控件中显示必应中国中文地图、谷歌中国中文地图。

    原文:如何在WindowsPhone Bing Map控件中显示必应中国中文地图.谷歌中国中文地图. 最近正好有点业余时间,所以在做做各种地图.Bing Map控件本身就能显示必应地图,但是很遗憾微软 ...

  5. Web监听器导图详解(转)

    阅读目录 Web监听器 监听器的分类 Servlet版本与Tomcat版本 getAttribute与getParameter的区别 参考 监听器是JAVA Web开发中很重要的内容,其中涉及到的知识 ...

  6. oracle看到用户的所有表名、表睐、字段名称、现场的目光、是空的、字段类型

    --oracle看到用户的所有表名.表睐.字段名称.现场的目光.是空的.字段类型 select distinct TABLE_COLUMN.*, TABLE_NALLABLE.DATA_TYPE, T ...

  7. windows phone (22) 隐藏元素

    原文:windows phone (22) 隐藏元素 在wp中我们也会用到隐藏某个元素,已达到某种效果,刚刚从文章看到了,分享一下[作者:神舟龙] Visibility 此属性能非常方便的实现隐藏某个 ...

  8. Connecting Docker for Cloud Services using SDN and Network Virtualization

     Abstract The explosive scale of container CPUs needs highly efficient network virtualization Chal ...

  9. DevExpress控件使用之RichEditControl的使用

    原文:DevExpress控件使用之RichEditControl的使用 做Winform的,我们一般都知道,传统.NET界面有一个RichTextBox控件,这个是一个富文本控件,可以存储图片文字等 ...

  10. 如何解决Android SDK无法下载Package的问题(.net)

    有些用户在安装好Android SDK后,打开Android SDK Manager下载API时一直显示“Done loading packages”却迟迟不能前进,界面显示的Package空空如也. ...