如果已知最小生成樹,將未在生成樹的一條路徑加入生成樹必會產生乙個環,刪除環中除剛新增的一條以外的最大邊剩下的就是次小生成樹.求最小生成樹時用maxd陣列儲存兩點間最大的一條邊刪除時使用.
#include #define inf 0x3f3f3f3f
using namespace std;
const int maxn=505;
bool vis[maxn];
bool connect[maxn][maxn];//是否邊已被使用過
int dis[maxn];//dis為點到最小生成樹集合的最近距離
int maxd[maxn][maxn];
int pre[maxn];//父節點
int v,e,a,b,c;
int prim()
dis[1]=0;
//pre[1]=0;
for(int i=2;i<=v;i++)
if(f(prim())) cout<<"yes"
}
NYOJ 118 修路方案
時間限制 3000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍率領著許多部隊,它們分別駐紮在n個不同的城市裡,這些城市分別編號1 n,由於交通不太便利,南將軍準備修路。現在已經知道哪些城市之間可以修路,如果修路,花費是多少。現在,軍師小工已經找到了一種修路的方案,能夠使各個城市都聯通...
NYOJ 118 修路方案
時間限制 3000 ms 記憶體限制 65535 kb 難度 5描述 南將軍率領著許多部隊,它們分別駐紮在n個不同的城市裡,這些城市分別編號1 n,由於交通不太便利,南將軍準備修路。現在已經知道哪些城市之間可以修路,如果修路,花費是多少。現在,軍師小工已經找到了一種修路的方案,能夠使各個城市都聯通起...
nyoj 118 修路方案
時間限制 3000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍率領著許多部隊,它們分別駐紮在n個不同的城市裡,這些城市分別編號1 n,由於交通不太便利,南將軍準備修路。現在已經知道哪些城市之間可以修路,如果修路,花費是多少。現在,軍師小工已經找到了一種修路的方案,能夠使各個城市都聯通...