麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

【DP入門】矩形嵌套

2019-11-14 11:11:14
字體:
供稿:網(wǎng)友

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

描述

有n個矩形,每個矩形可以用a,b來描述,表示長和寬。矩形X(a,b)可以嵌套在矩形Y(c,d)中當(dāng)且僅當(dāng)a<c,b<d或者b<c,a<d(相當(dāng)于旋轉(zhuǎn)X90度)。例如(1,5)可以嵌套在(6,2)內(nèi),但不能嵌套在(3,4)中。你的任務(wù)是選出盡可能多的矩形排成一行,使得除最后一個外,每一個矩形都可以嵌套在下一個矩形內(nèi)。輸入第一行是一個正正數(shù)N(0<N<10),表示測試數(shù)據(jù)組數(shù),每組測試數(shù)據(jù)的第一行是一個正正數(shù)n,表示該組測試數(shù)據(jù)中含有矩形的個數(shù)(n<=1000)隨后的n行,每行有兩個數(shù)a,b(0<a,b<100),表示矩形的長和寬輸出

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

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

代碼如下:

#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,可以作為練習(xí)。本題解法很常見,會經(jīng)常用到。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久久久久久一区二区三区 | 激情夜色 | 国产一级午夜 | 香蕉久久久久久 | 免费看搡女人无遮挡的视频 | 毛片视频网址 | 毛片免费一区二区三区 | 羞羞网站在线看 | 成年免费在线视频 | 国产精品久久久久久久久久电影 | 亚洲综合精品成人 | 久久久久亚洲国产精品 | 亚洲国产精品一区二区久久 | 毛片免费一区二区三区 | 97zyz成人免费视频 | 91精品国产综合久久婷婷香蕉 | 看免费5xxaaa毛片 | 色偷偷一区| 国产成人精品无人区一区 | 久久成人免费观看 | 91在线精品亚洲一区二区 | 久久国产乱子伦精品 | 久草在线新时代视觉 | 欧美日韩在线视频一区 | 91精品国产综合久久久欧美 | 欧美精品v国产精品v日韩精品 | 天天夜碰日日摸日日澡性色av | a级高清免费毛片av在线 | 国产精品999在线 | 五月天影院,久久综合, | 美女性感毛片 | 久久久久久久久成人 | 日韩精品羞羞答答 | mmmwww| 精品一区久久久 | 国产成人在线视频 | 亚洲成人激情av | chinese xxxxhd videos麻豆 | 欧美日韩色片 | 黄网站在线播放视频免费观看 | 男人天堂新地址 |