黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

[ACM]簡(jiǎn)單動(dòng)態(tài)規(guī)劃——電路布線

系統(tǒng) 2078 0

電路布線

【問(wèn)題描述】
在一塊電路板的上、下兩端分別有n個(gè)接線柱。根據(jù)電路設(shè)計(jì),要求用導(dǎo)線(i,π(i))將上端接線柱i與下端接線柱π(i)相連,如圖所示。

動(dòng)態(tài)規(guī)劃——電路布線

其中,π(i),1<=i<=n是{1,2,…,n}的一個(gè)排列。導(dǎo)線(i,π(i))稱(chēng)為該電路板上的第i條連線。對(duì)于任何1<=i π(j)。

在制作電路板時(shí),要求將這n條連線分布到若干絕緣層上。在同一層上的連線不相交。你的任務(wù)是要確定將哪些連線安排在第一層上,使得該層上有盡可能多的連線。換句話說(shuō),就是確定導(dǎo)線集Nets={ i,π(i),1<=i<=n}的最大不相交子集。

【輸入形式】
輸入文件第一行為整數(shù)n;第二行為用一個(gè)空格隔開(kāi)的n個(gè)整數(shù),表示π(i)。

【輸出形式】
輸出文件第一行為最多的連線數(shù)m,第2行到第m+1行輸出這m條連線(i,π(i))。

【輸入樣例】
10
1 8
2 7
3 4
4 2
5 5
6 1
7 9
8 3
9 10
10 6

【輸出樣例】
4

思路如下:

比較基礎(chǔ)的動(dòng)態(tài)規(guī)劃問(wèn)題,設(shè)a[i][j]為上端接線柱i與下端接線柱j前的最大不相交子集,則:

  1. 若i與j不相連,則i與j前的最大不想交子集等于i與j - 1前或i - 1與j前的最大不相交子集的最大值,即a[i][j] = max(a[i][j - 1], a[i - 1][j])
  2. 若i與j相連,則i與j前的最大不想交子集等于i - 1與j - 1前的最大不想交子集加1,即a[i][j] = a[i - 1][j - 1] + 1
    #include<stdio.h>

inline int max(int a, int b){
	return a > b ? a : b;
}

int main(){
	int n, i, j;
	int a[100][100], b[100];
	a[0][0] = 0;
	scanf("%d", &n);
	for(i = 0; i < n; ++i){
		int j;
		scanf("%d", &j);
		scanf("%d", &b[j]);
		a[i][0] = 0;
		a[0][i] = 0;
	}
	for(i = 1; i <= n; ++i){
		for(j = 1; j <= n; ++j){
			if(b[i] == j){
				a[i][j] = a[i - 1][j - 1] + 1;
			}else{
				a[i][j] = max(a[i - 1][j], a[i][j - 1]);
			}
		}
	}
	printf("%d\n", a[n][n]);
	return 0;
}
  


=======================簽 名 檔=======================
原文地址(我的博客): http://www.clanfei.com/2012/06/1332.html
歡迎訪問(wèn)交流,至于我為什么要多弄一個(gè)博客,因?yàn)槲覠釔?ài)前端,熱愛(ài)網(wǎng)頁(yè),我更希望有一個(gè)更加自由、真正屬于我自己的小站,或許并不是那么有名氣,但至少能夠讓我為了它而加倍努力。。
=======================簽 名 檔=======================




[ACM]簡(jiǎn)單動(dòng)態(tài)規(guī)劃——電路布線


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦?。?!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論