最小生成树模板

http://acm.fjut.edu.cn/Problem.jsp?pid=1545

FJUTOJ 1545

Prim

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 #include <iostream>
 5 
 6 using namespace std;
 7 #define M 105
 8 
 9 const int INF=1<<29;
10 
11 int n,m,arr[M][M];
12 
13 int prim()
14 {
15     int dis[M],vis[M],i,j,u,ans=0;
16     for(i=1;i<=n;i++)
17         dis[i]=arr[1][i],vis[i]=0;
18     vis[1]=1;
19     for(i=1;i<n;i++)
20     {
21         int mi=INF;
22         for(j=1;j<=n;j++)
23         {
24             if(!vis[j]&&dis[j]<mi)
25             {
26                 mi=dis[j];
27                 u=j;
28             }
29         }
30         vis[u]=1;
31         ans+=dis[u];
32         for(j=1;j<=n;j++)
33         {
34             if(!vis[j]&&arr[u][j]<dis[j])
35             {
36                 dis[j]=arr[u][j];
37             }
38         }
39     }
40     return ans;
41 }
42 
43 int main()
44 {
45     int i,j,a,b,c;
46     while(scanf("%d",&n)&&n)
47     {
48         for(i=1;i<=n;i++)
49         {
50             for(j=1;j<=n;j++)
51             {
52                 arr[i][j]=INF;
53             }
54         }
55         scanf("%d",&m);
56         while(m--)
57         {
58             scanf("%d%d%d",&a,&b,&c);
59             arr[a][b]=arr[b][a]=min(arr[a][b],c);
60         }
61         printf("%d\n",prim());
62 
63     }
64     return 0;
65 }
View Code
kruskal
 1 #include<cstdio>
 2 #include<algorithm>
 3 using namespace std;
 4 struct edge
 5 {
 6     int from,to,cost;
 7 }arr[105*105];
 8 int n,m,pre[105];
 9 void init()
10 {
11     for(int i=1;i<=n;i++)
12     {
13         pre[i]=i;
14     }
15 }
16 int findx(int x)
17 {
18     if(pre[x]==x)return x;
19     else return pre[x]=findx(pre[x]);
20 }
21 void join(int x,int y)
22 {
23     int fx=findx(x),fy=findx(y);
24     if(fx==fy)return;
25     pre[fy]=fx;
26 }
27 bool same(int x,int y)
28 {
29     return findx(x)==findx(y);
30 }
31 bool cmp(edge a,edge b)
32 {
33     return a.cost<b.cost;
34 }
35 int kruskal()
36 {
37     int ans=0;
38     sort(arr+1,arr+1+m,cmp);
39     for(int i=1;i<=m;i++)
40     {
41         if(same(arr[i].from,arr[i].to))
42         {
43             continue;
44         }
45         join(arr[i].from,arr[i].to);
46         ans+=arr[i].cost;
47     }
48     return ans;
49 }
50 int main()
51 {
52     while(scanf("%d",&n)&&n)
53     {
54         scanf("%d",&m);
55         init();
56         for(int i=1;i<=m;i++)
57         {
58             scanf("%d%d%d",&arr[i].from,&arr[i].to,&arr[i].cost);
59         }
60         printf("%d\n",kruskal());
61     }
62 }
View Code

 

posted @ 2017-04-06 23:15  Q1143316492  阅读(118)  评论(0编辑  收藏  举报