題目描述:
給定一張圖,問如何順序排列結點,能使排列中任意有邊相連的兩個節點之間的距離最大的值最小,如果有兩個排列最大值相等,請輸出字典序小的
分析:排列樹+剪枝
在構造排列樹的同時檢查當前已經構成的序列中最大值是否小於最優質,如果大於剪掉即可
#include #include #include using namespace std;
int g[27][27];
int pm[27];
bool f[27];
int id;
int ans[27];
int maxx;
void permutation(int n,int *a,int cur)
return 0;
}
遞迴回溯 UVa140 Bandwidth寬頻
本題題意 尋找乙個排列,在此排序中,頻寬的長度最小 頻寬是指 任意一點v與其距離最遠的且與v有邊相連的頂點與v的距離的最大值 若有多個,按照字典序輸出最小的哪乙個。解題思路 方法一 由於題目說結點的個數最多是8個,所以,最先想到的方法是暴力列舉,將所有的結點全排列,然後找到寬頻長度最小的那乙個,此方...
140 Bandwidth(排列(頻寬問題))
題目 140 bandwidth 題目大意 給出一些點,點和點之間是否相連,求這些點怎麼排列可以使的所有點形成的圖的頻寬最小。如果有多種情況按照字典序輸出。圖的頻寬指的是點的頻寬的最大值,點的頻寬指的是,所有和這個點聯通的其他的點到這個點的距離的最大值。解題思路 轉換成全排列問題。將這裡點和點的聯通...
UVA 140 全排列 剪枝
題意 給定n n 8 個節點的圖和乙個節點的排列,定義節點i的頻寬為i和相鄰節點在排列中的最遠距離,整個圖的頻寬便是每個節點頻寬的最大值,給定圖g,求出讓頻寬最小的節點排列。題解 因為資料範圍不大,所以直接用next permutation函式列舉每種情況,對每個排列ji其實進行計算,當得到的最大值...