传送门

题意:

  现在我们有 n 个信封,然后我们有一张卡片,并且我们知道这张卡片的长和宽。

  现给出这 n 个信封的长和宽,我们想形成一个链,这条链的长度就是这条链中所含有的信封的数量;

  但是需要满足①信封a可以连接信封b当且仅当信封a的长和宽分别严格小于信封b的长和宽。

             ②构成这条长链的所有信封的长和宽分别严格小于卡片的长和宽。

  问最多可以形成多长的链,并且输出我们选取的链的编号;

题解:

  DAG上的动态规划;

  如果信封对于任意两个信封 a,b 满足上述条件①②,那么连一条由a指向b的有向边;

  O(n2)预处理出所有满足条件的(a,b);

  求解DAG上的最长路;

  正解,nice,可你别忘了,最大需要开 n2 = 25000000 的数组存图,emmm;

  

  然后,不断地试探,最终

  

  啊,最后一个点,翻车了;

  出题人也太坏了叭;  

  正解:首先对于这 n 个信封,按照 w 从小到大排序,然后,找 h 的最长上升子序列;

AC代码:

 #include<bits/stdc++.h>
using namespace std;
#define memF(a,b,n) for(int i=0;i <= n;a[i]=b,++i);
const int maxn=5e3+; int n,w,h;
struct Date
{
int w,h;
int id;
bool operator < (const Date& obj) const
{
return w < obj.w;
}
}_date[maxn];
int dp[maxn]; bool isSat(int i,int j)
{
return _date[i].w < _date[j].w && _date[i].h < _date[j].h;
}
void Solve()
{
sort(_date+,_date+n+);
memF(dp,,n);
for(int i=n-;i >= ;--i)
for(int j=i+;j <= n;++j)
if(isSat(i,j))
dp[i]=max(dp[j]+,dp[i]); int ans=;
int cur;
for(int i=;i <= n;++i)
if(isSat(,i) && dp[i] > ans)
{
ans=dp[i];
cur=i;
} printf("%d\n",ans);
if(ans == )
return ; printf("%d",_date[cur].id);
for(int i=;i <= n;++i)
if(dp[i] == dp[cur]- && isSat(cur,i))
printf(" %d",_date[i].id),cur=i;
printf("\n");
}
int main()
{
scanf("%d%d%d",&n,&w,&h);
for(int i=;i <= n;++i)
{
scanf("%d%d",&_date[i].w,&_date[i].h);
_date[i].id=i;
}
_date[]={w,h}; Solve(); return ;
}

Codeforces Beta Round #4 (Div. 2 Only) D. Mysterious Present(LIS)的更多相关文章

  1. Codeforces Beta Round #4 (Div. 2 Only) D. Mysterious Present 记忆化搜索

    D. Mysterious Present 题目连接: http://www.codeforces.com/contest/4/problem/D Description Peter decided ...

  2. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  3. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  4. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  5. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

  6. Codeforces Beta Round #76 (Div. 2 Only)

    Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...

  7. Codeforces Beta Round #75 (Div. 2 Only)

    Codeforces Beta Round #75 (Div. 2 Only) http://codeforces.com/contest/92 A #include<iostream> ...

  8. Codeforces Beta Round #74 (Div. 2 Only)

    Codeforces Beta Round #74 (Div. 2 Only) http://codeforces.com/contest/90 A #include<iostream> ...

  9. Codeforces Beta Round #73 (Div. 2 Only)

    Codeforces Beta Round #73 (Div. 2 Only) http://codeforces.com/contest/88 A 模拟 #include<bits/stdc+ ...

随机推荐

  1. Leetcode867.Transpose Matrix转置矩阵

    给定一个矩阵 A, 返回 A 的转置矩阵. 矩阵的转置是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引. 示例 1: 输入:[[1,2,3],[4,5,6],[7,8,9]] 输出:[[1,4,7] ...

  2. 利用Eclipse进行远程Debug

    这项功能真的十分赞,当我不想写junit test,又想调试在实际环境中才能起作用的Java程序,远程debug真的是太好用了. 参数:java -jar -Xdebug -Xrunjdwp:tran ...

  3. SDUT-2140_判断给定图是否存在合法拓扑序列

    数据结构实验之图论十:判断给定图是否存在合法拓扑序列 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定一个有向图,判 ...

  4. C#文件读写(txt 简单方式)

    1.文件写入 // 路径,写入内容 System.IO.File.WriteAllText(@".\File.txt", string.Empty); 可更换相应的方法 2.文件读 ...

  5. JAVA高级特性--自动拆箱-装箱,枚举类型

    基本数据类型转换为引用类型对象 一个自动装箱的例子 Integer i=10; 相当于 Integer i=new Integer(10); 一个自动拆箱的例子 Integer m=10; int n ...

  6. Android BroadcastReceiver 简介

    Android BroadcastReceiver 简介  在 Android 中使用 Activity, Service, Broadcast, BroadcastReceiver     活动(A ...

  7. find 使用搜集

    find:-atime +n/-n:表示访问或执行时间大于或小于n天的文件-ctime +n/-n:表示写入.更改inode属性的时间大于或小于n天的文件-mtime +n/-n:表示写入时间大于或小 ...

  8. SDWebImage源码解析之SDWebImageManager的注解

    http://www.cocoachina.com/ios/20150612/12118.html 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...

  9. 自定义View系列教程08--滑动冲突的产生及其处理

    深入探讨Android异步精髓Handler 站在源码的肩膀上全解Scroller工作机制 Android多分辨率适配框架(1)- 核心基础 Android多分辨率适配框架(2)- 原理剖析 Andr ...

  10. 【转载】字符编码笔记:ASCII,Unicode和UTF-8

    字符编码笔记:ASCII,Unicode和UTF-8 作者: 阮一峰 今天中午,我突然想搞清楚Unicode和UTF-8之间的关系,于是就开始在网上查资料. 结果,这个问题比我想象的复杂,从午饭后一直 ...