描述

有n个矩形,每个矩形可以用a,b来描述,表示长和宽。矩形X(a,b)可以嵌套在矩形Y(c,d)中当且仅当a<c,b<d或者b<c,a<d(相当于旋转X90度)。例如(1,5)可以嵌套在(6,2)内,但不能嵌套在(3,4)中。你的任务是选出尽可能多的矩形排成一行,使得除最后一个外,每一个矩形都可以嵌套在下一个矩形内。

输入
第一行是一个正正数N(0<N<10),表示测试数据组数,
每组测试数据的第一行是一个正正数n,表示该组测试数据中含有矩形的个数(n<=1000)
随后的n行,每行有两个数a,b(0<a,b<100),表示矩形的长和宽
输出
每组测试数据都输出一个数,表示最多符合条件的矩形数目,每组输出占一行
样例输入
1
10
1 2
2 4
5 8
6 10
7 9
3 1
5 8
12 10
9 7
2 2
样例输出
5

解题思路:

采用与求最长递增子序列类似的方式,不断保存前面的最多矩阵序列,然后再不断更新这个序列的集合。

上面是解法一,解法二是每次所有矩阵,先扫描第一个矩阵,然后从1---N个矩阵,如果第一个矩阵可以包含第I个矩阵,并且满足第i个矩阵最多矩阵列小于等于第一个矩阵那么更新第I个矩阵,使得A[i]=A[1]+1;对于其他2...N个矩阵也可以这样操作。

 //观察是否满足矩形P1,在矩形P2内部
public static bool IsMatch(rectAngle p1, rectAngle p2)
{
bool flag = (p1.getX() < p2.getX() && p1.getY() < p2.getY()) || (p1.getX() < p2.getY() && p1.getY() < p2.getX());
return flag;
} public static int HaveRectangleCount(List<rectAngle> P)
{
int[,] M = new int[P.Count, P.Count];
int[] dp = new int[P.Count];
int biggest = ;
for (int k = ; k < P.Count; k++)
dp[k] = ;
rectAngle[] x = new rectAngle[P.Count + ];
x[] = new rectAngle(, );
//解法一
for (int i = ; i < P.Count; i++)
{
for (int j = count; j >= ; j--)
{
if (IsMatch(x[j], P[i]))
{
x[j + ] = new rectAngle(P[i].getX(), P[i].getY());
if (j == count)
count++;
break;
}
}
}
outPutrectAngle(x.ToList<rectAngle>(), count);//输出一个满足条件的矩阵例子
Console.WriteLine("count=" + count); //解法二、不断搜索,更新其排位表
for (int i = ; i < P.Count; i++)
{
for (int j = ; j < P.Count; j++)
{
if (IsMatch(P[i], P[j]) && (dp[i] >= dp[j]))
dp[j] = dp[i] + ;
Console.Write(dp[j] + " ");//输出此时的每个元素的排位,观察其变化过程。
}
Console.WriteLine();
} for (int i = ; i < P.Count; i++)
{
if (dp[i] > biggest)
biggest = dp[i];
}
return biggest;
} public static void outPutrectAngle(List<rectAngle> P, int Len)
{
for (int i = ; i <= Len; i++)
{
Console.Write("x=" + P[i].getX() + ",y=" + P[i].getY() + ", ");
}
Console.WriteLine();
}

最新文章

  1. ASP.NET Identity入门系列教程(一) 初识Identity
  2. MySQL备份还原&mdash;&mdash;AutoMySQLBackup介绍
  3. js Math 对象的方法
  4. Oracle客户端+PLSQLDeveloper实现远程登录Oracle数据库
  5. yii url美化 urlManager组件
  6. rabbitmq-server启动不了,安装erlang,安装rabbitmq-server
  7. Gmail邮箱添加域名解析
  8. (整理)RPC
  9. CSV 文件读取类
  10. C# 与C/C++相互调用
  11. xml 与 DataSet 互相转换
  12. 22. Generate Parentheses
  13. 使用WireShark简单分析ICMP报文
  14. 【JDK1.8】JUC——AbstractQueuedSynchronizer
  15. Yii2设计模式——静态工厂模式
  16. Kafka笔记8(管理Kafka)
  17. P1601高精度加法
  18. Two Sum IV - Input is a BST LT653
  19. 前端开发不容错过的jQuery图片滑块插件(转)
  20. 如何实用便捷的在本地真机调试WEB端HTML5网页

热门文章

  1. 项目开发--&gt;一键登录功能汇总
  2. Spring与apache CXF结合实例
  3. 【CentOS】安装chrome
  4. js中的null VS undefined
  5. 5种你未必知道的JavaScript和CSS交互的方法
  6. ExtJs之字段集FieldSet
  7. POJ 3320
  8. POJ 1665
  9. 树莓派/RaspberryPi 内核编译
  10. Android View体系