nyoj118 修路方案 次小生成樹

2021-08-30 17:57:05 字數 558 閱讀 2801

如果已知最小生成樹,將未在生成樹的一條路徑加入生成樹必會產生乙個環,刪除環中除剛新增的一條以外的最大邊剩下的就是次小生成樹.求最小生成樹時用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,由於交通不太便利,南將軍準備修路。現在已經知道哪些城市之間可以修路,如果修路,花費是多少。現在,軍師小工已經找到了一種修路的方案,能夠使各個城市都聯通...