国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

【DP入門】矩形嵌套

2019-11-14 10:45:39
字體:
來源:轉載
供稿:網友

題目來自nyist第16題,如下:

描述

有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),表示矩形的長和寬輸出

每組測試數據都輸出一個數,表示最多符合條件的矩形數目,每組輸出占一行

要能實現嵌套,首先要將所有矩形按照大小排序,并先將矩形旋轉成長寬方向一致。排序使用sort函數,由于排序之后只可能前面的矩形嵌套在后面的矩形之中,故用DP解法遞推,雙循環i,j(循環結束標志i<n,j<i)即對第i個矩形,循環查找其前面的i-1個矩形,找出能被其嵌套并且對應dp數組的值+1后大于dp[i]的,dp數組在本題中指嵌套在第i個矩形中的矩形個數(我在程序中初始化為1)。找出后更新dp[i]的值。計算完dp數組之后,找出其中的最大值,即為嵌套矩形的最大層數。

代碼如下:

#include<cstdio>#include<algorithm>using namespace std;struct Re{	int a,b;}rectangle[1000+5];int dp[1000+5];int cmp(struct Re x,struct Re y){	if(x.a == y.a) return x.b <= y.b;	return x.a <= y.a;}int main(){	int n,N,i,j,k,t;	scanf("%d",&N);	while(N--)	{		scanf("%d",&n);		for(i = 0;i < n;i++)		{			scanf("%d %d",&(rectangle[i].a),&(rectangle[i].b));			if(rectangle[i].a > rectangle[i].b)			{				t = rectangle[i].a;				rectangle[i].a = rectangle[i].b;				rectangle[i].b = t; 			}		}		sort(rectangle,rectangle+n,cmp);		for(i = 0;i < n;i++)		{			dp[i] = 1;			for(j = 0;j < i;j++)			{				if(rectangle[i].a > rectangle[j].a && rectangle[i].b > rectangle[j].b && (dp[j]+1) > dp[i])					dp[i] = dp[j]+1;			}		}		int max = 0;	//因為dp[i]初始化為0		for(i = 0;i < n;i++)			max = max > dp[i] ? max : dp[i];		PRintf("%d/n",max);	} 	return 0;} 

本題還可以用貪心求解,方法是在排序之后,貪心選擇能包含最多的序列,雖然能跑過,但是我不會證明其正確性,有些頭疼。

類似問題還有poj1065,可以作為練習。本題解法很常見,會經常用到。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沧源| 扶余县| 东辽县| 绍兴市| 安阳县| 柘城县| 明溪县| 邻水| 綦江县| 晋江市| 铜鼓县| 桂林市| 拉萨市| 溧水县| 黎平县| 神木县| 海原县| 志丹县| 清镇市| 许昌县| 垦利县| 芮城县| 长宁县| 抚州市| 平舆县| 玉溪市| 惠水县| 宁陕县| 兰州市| 顺义区| 如东县| 兴山县| 方城县| 南城县| 兴和县| 原阳县| 清水河县| 新津县| 株洲县| 秭归县| 南皮县|