概念
有帶權圖G, 對於圖中每條邊e[i], 都有benifit[i](收入)和cost[i](花費), 我們要求的是一棵生成樹T, 它使得 ∑(benifit[i])
/ ∑(cost[i]), i∈T 最大(或最小).
解法:0-1分數規劃
設x[i]等於1或0, 表示邊e[i]是否屬於生成樹.
則我們所求的比率 r = ∑(benifit[i] * x[i]) / ∑(cost[i] * x[i]), 0≤i
為了使 r 最大, 設計一個子問題---> 讓 z = ∑(benifit[i] * x[i]) - l * ∑(cost[i] * x[i]) = ∑(d[i] * x[i]) 最大 (d[i] = benifit[i] - l * cost[i]) , 並記為z(l).
然後明確兩個性質:
1. z單調遞減
證明: 因為cost為正數, 所以z隨l的減小而增大.
2. z( max(r) ) = 0
證明: 若z( max(r) ) < 0, ∑(benifit[i] * x[i]) - max(r) * ∑(cost[i] * x[i]) < 0, 可化為 max(r) < max(r). 矛盾;
若z( max(r) ) >= 0, 根據性質1, 當z = 0 時r最大.
/*
ID: [email protected]
PROG:
LANG: C++
*/
#include