普里姆Prim— 最小生成树

 

#include<stdio.h>// 用prim算法构造五项连通图网的最小生成树
#define maxcost 1000
int gm[50][50];

void prim(int tree[],int cost[],int n)
{//从序号为0的顶点出发,建立连通网的最小生成树,二维数组gm[][]是其邻接矩阵
 //顶点编号依次为0......n-1,建立的最小生成树存于数组tree中,对应的边值在cost中

 int flag[50]={0};//标记数组,用于记录点是否加入到U中
 int i,j,k,mincost;

 for(i=0;i<n;i++)
 {
  cost[i]=gm[0][i];//从存储序号为0的顶点出发生成最小生成树
  tree[i]=0;
 }
// tree[0]=-1;

 flag[0]=1;//顶点0进入U

    for(i=1;i<n;i++)
 {
  mincost=maxcost;
  for(j=1;j<n;j++)
  {
   if(flag[j]==0&&cost[j]<mincost)
   {
     mincost=cost[j];
     k=j;//记忆最小的边
   }
  }
  
  flag[k]=1;//k加入U集合
  printf("k==%d\n",k);
  

  for(j=1;j<n;j++)
   if(flag[j]==0&&gm[k][j]<cost[j])//其中条件flag[j]==0是非常重要的
   {
    cost[j]=gm[k][j];//更新cost[]的最新值
    tree[j]=k;
    printf("    %d->%d\n",k,j);
   // printf("j==%d\n",j);
   }
 }
}


int main()
{  freopen("1.txt","r",stdin);
   printf("以序号为0的顶点出发生成最小生成树\n");
   int i,j,k,n,e,c;
   int tree[50],cost[50];
  
   scanf("%d%d",&n,&e);
   for(i=0;i<n;i++)
    for(j=0;j<n;j++)
     gm[i][j]=maxcost;

    for(k=1;k<=e;k++)
    {
     scanf("%d%d%d",&i,&j,&c);
     gm[i][j]=gm[j][i]=c;
    }

    prim(tree,cost,n);

    for(i=0;i<n;i++)
     printf("tree[%d]==%d\n",i,tree[i]);
   
    printf("\n");

    return 0;
}

 

//测试用例

/*7 10
0 1 50
0 2 60
1 3 65
1 4 40
2 3 52
2 6 45
3 4 50
3 5 30
3 6 42
4 5 70*/


 

 


   

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gdliweibing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值