poj 2485 求最小生成树中 最长的一条边

Sample Input

1 //T

3 //n
0 990 692 //邻接矩阵
990 0 179
692 179 0
Sample Output

692

 

 

prim

 1 # include <iostream>
 2 # include <cstdio>
 3 # include <cstring>
 4 # include <algorithm>
 5 # include <cmath>
 6 # define LL long long
 7 using namespace std ;
 8 
 9 const int INF=0x3f3f3f3f;
10 const int MAXN=510;
11 bool vis[MAXN];
12 int lowc[MAXN];
13 int n ;
14 int cost[MAXN][MAXN] ;
15 int MAX = 0 ;
16 
17 int Prim()//点是0~n-1
18 {
19     int ans=0;
20     memset(vis,false,sizeof(vis));
21     vis[0]=true;
22     for(int i=1;i<n;i++)lowc[i]=cost[0][i];
23     for(int i=1;i<n;i++)
24     {
25         int minc=INF;
26         int p=-1;
27         for(int j=0;j<n;j++)
28             if(!vis[j]&&minc>lowc[j])
29             {
30                 minc=lowc[j];
31                 p=j;
32             }
33             if(minc==INF)return -1;//原图不连通
34             ans+=minc;
35             if (minc > MAX)
36                 MAX = minc ;
37             vis[p]=true;
38             for(int j=0;j<n;j++)
39                 if(!vis[j]&&lowc[j]>cost[p][j])
40                     lowc[j]=cost[p][j];
41     }
42     return ans;
43 }
44 
45 int main()
46 {
47 
48    // freopen("in.txt","r",stdin) ;
49     int T ;
50     cin>>T ;
51     while(T--)
52     {
53         cin>>n ;
54         int w ;
55         int i , j ;
56         for (i = 0 ; i < n ; i++)
57             for (j = 0 ; j < n ; j++)
58                {
59                    cin>>w ;
60                    if(w==0)
61                      cost[i][j] = INF ;
62                    else
63                      cost[i][j] = w ;
64                }
65         MAX = 0 ;
66         Prim() ;
67         cout<<MAX<<endl ;
68 
69     }
70     return 0 ;
71 }
View Code

 

posted @ 2015-06-14 14:37  __Meng  阅读(266)  评论(0编辑  收藏  举报