5985: 矩形嵌套

题意:求最长递增子序列(包含两个元素)

思路:先找出关系式子;

li=lj+1(当ai<aj时)

两层循环 第一层i从1-n

第二层j 从0-i ;求出i前面的每个j 的max长度再加上自己即1 so要初始化dp【0-n】=1

#include<bits/stdc++.h>
using namespace std;
struct node{
int x,y;
}qu[1005];
bool cmp(node a,node b)
{
if(a.x==b.x)return a.y<b.y;
return a.x<b.x;
}
int dp[1005];
int main()
{
int t,n,i,j;
cin>>t;
while(t--){
cin>>n;
for(i=0;i<n;i++){
int u,v;cin>>u>>v;
qu[i].x=min(u,v);
qu[i].y=max(u,v);
dp[i]=1;
}
sort(qu,qu+n,cmp);
for(i=1;i<n;i++){
for(j=0;j<i;j++){
// cout<<i<<" i-j "<<j<<" ";
if(qu[j].x<qu[i].x&&qu[j].y<qu[i].y){
// cout<<dp[i]<<" "<<dp[j]+1;
dp[i]=max(dp[i],dp[j]+1);
}
// cout<<endl;
}
}
int maxx=dp[0];
for(i=1;i<n;i++)maxx=max(maxx,dp[i]);
cout<<maxx<<endl;
}
return 0;
}

3229: Rectangles

解法同上

#include<bits/stdc++.h>
using namespace std;
struct node{
int x1,y1,x2,y2;
}qu[1005];
bool cmp(node a,node b)
{
return a.x1<b.x1|| a.x1==b.x1&&a.y1<b.y1|| a.x1==b.x1&&a.y1==b.y1&&a.x2<b.x2|| a.x1==b.x1&&a.y1==b.y1&&a.x2==b.x2&&a.y2<b.y2;
}
int dp[1005];
int main()
{
int t,n,i,j;
while(scanf("%d",&n),n!=0){
for(i=0;i<n;i++){
scanf("%d%d%d%d",&qu[i].x1,&qu[i].y1,&qu[i].x2,&qu[i].y2);
dp[i]=1;
}
sort(qu,qu+n,cmp);
for(i=1;i<n;i++){
for(j=0;j<i;j++){
if(qu[j].x2<qu[i].x1&&qu[j].y2<qu[i].y1){
dp[i]=max(dp[i],dp[j]+1);
}
}
}
int maxx=dp[0];
for(i=1;i<n;i++)maxx=max(maxx,dp[i]);
printf("%d\n",maxx);
}
return 0;
}

这题也可以用记忆化搜索

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1005;
struct p{
int x1,x2,y1,y2;
}rec[N];
int vis[N][N],res[N],n;
int dfs(int u)
{
if(res[u]) return res[u];
for(int i=0;i<n;i++)
if(vis[u][i]) res[u]=max(res[u],dfs(i)+1);
res[u]=max(res[u],1);
return res[u];
}
void init()
{
memset(vis,0,sizeof(vis));
memset(res,0,sizeof(res));
}
int main()
{
while(~scanf("%d",&n),n)
{
init();
for(int i=0;i<n;i++) scanf("%d%d%d%d",&rec[i].x1,&rec[i].y1,&rec[i].x2,&rec[i].y2);
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
if(rec[i].x2<rec[j].x1&&rec[i].y2<rec[j].y1) vis[i][j]=1;
int ans=0;
for(int i=0;i<n;i++)
ans=max(ans,dfs(i));
printf("%d\n",ans);
}
}

最长上升子序列(LIS) dp典型例题(tzoj 矩形嵌套,Rectangles )的更多相关文章

  1. 动态规划(DP),最长递增子序列(LIS)

    题目链接:http://poj.org/problem?id=2533 解题报告: 状态转移方程: dp[i]表示以a[i]为结尾的LIS长度 状态转移方程: dp[0]=1; dp[i]=max(d ...

  2. 1. 线性DP 300. 最长上升子序列 (LIS)

    最经典单串: 300. 最长上升子序列 (LIS) https://leetcode-cn.com/problems/longest-increasing-subsequence/submission ...

  3. 最长回文子序列LCS,最长递增子序列LIS及相互联系

    最长公共子序列LCS Lintcode 77. 最长公共子序列 LCS问题是求两个字符串的最长公共子序列 \[ dp[i][j] = \left\{\begin{matrix} & max(d ...

  4. 最长上升子序列LIS(51nod1134)

    1134 最长递增子序列 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 给出长度为N的数组,找出这个数组的最长递增子序列.(递增子序列是指,子序列的元素是递 ...

  5. 最长上升子序列(LIS)与最长公共子序列(LCS)

    1.LIS : 给定一个序列,求它的最长上升子序列(n<=2000) 第一种 O(n^2): dp[i] 为以i为开头的最长上升子序列长度 code1: #include<cstdio&g ...

  6. 【部分转载】:【lower_bound、upperbound讲解、二分查找、最长上升子序列(LIS)、最长下降子序列模版】

    二分 lower_bound lower_bound()在一个区间内进行二分查找,返回第一个大于等于目标值的位置(地址) upper_bound upper_bound()与lower_bound() ...

  7. 2.16 最长递增子序列 LIS

    [本文链接] http://www.cnblogs.com/hellogiser/p/dp-of-LIS.html [分析] 思路一:设序列为A,对序列进行排序后得到B,那么A的最长递增子序列LIS就 ...

  8. 题解 最长上升子序列 LIS

    最长上升子序列 LIS Description 给出一个 1 ∼ n (n ≤ 10^5) 的排列 P 求其最长上升子序列长度 Input 第一行一个正整数n,表示序列中整数个数: 第二行是空格隔开的 ...

  9. POJ - 1631 Bridging signals(最长上升子序列---LIS)

    题意:左右各n个端口,已知n组线路,要求切除最少的线路,使剩下的线路各不相交,按照左端口递增的顺序输入. 分析: 1.设左端口为l,右端口为r,因为左端口递增输入,l[i] < l[j](i & ...

  10. 一个数组求其最长递增子序列(LIS)

    一个数组求其最长递增子序列(LIS) 例如数组{3, 1, 4, 2, 3, 9, 4, 6}的LIS是{1, 2, 3, 4, 6},长度为5,假设数组长度为N,求数组的LIS的长度, 需要一个额外 ...

随机推荐

  1. 无法识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次

    无法识别为 cmdlet.函数.脚本文件或可运行程序的名称.请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次 解决方法: 1.在开始菜单里找到Windows PowerShell.并以管理 ...

  2. Java_类与对象

    类与对象 概念 类是抽象的,概念的,代表一类事物,比如人类.猫类--,即它是数据类型. 对象是具体的,实际的,代表一个具体事物,即使实例. 类是对象的模板,对象是类的一个个体,对应一个实例 对象在内存 ...

  3. JavaScript&TypeScript学习总结

    目录 一.JavaScript学习总结 1.什么是JavaScript 2.变量 3.变量命名 4.操作符 5.遍历语句 6.函数 7.对象 8.数组 二.TypeScript学习总结 1.什么是Ty ...

  4. Lubuntu 18.04 自动登录

    参考文章:https://blog.csdn.net/qq_20965753/article/details/61420431 sudo nano /usr/share/lightdm/lightdm ...

  5. java的特性和版本

    java的特性 简单性 面向对象性 可移植性(跨平台性) 高性能 安全性 健壮性 多线程 分布式 动态性 java的三个版本 javaSE(标准版),主要是桌面程序开发 javaME(微型版),主要是 ...

  6. NodeJS增删改查的获取方法

    get獲取方法 ctx.query post獲取方法 ctx.request.body delete ctx.request.body put   ctx.query ctx.request.body

  7. 基于Nginx上的docker负载均衡

    1.首先需要拖拽镜像文件   docker  pull nginx 2.生成多个docker容器 docker run --name demo1 -d -p 8081:80 -v /data/demo ...

  8. git bash 笔记

    下载和安装 官网下载地址:https://git-scm.com/ 国内镜像下载地址:https://registry.npmmirror.com/binary.html?path=git-for-w ...

  9. py正则与re模块

    正则表达式符号介绍 按照博客中的表格罗列的去记即可 了解 \w,\s,\d与\W,\S,\D相反的匹配关系(对应的两者结合就是匹配全局) \t匹配制表符 \b匹配结尾的指定单词 优先掌握 ^:以什么什 ...

  10. 微信小程序-通过绑定事件进行传值

    一.数据绑定: <view bindtap="node" data-num="5"> 点击传值:{{nums}} </view> dat ...