普里姆算法—最小生成树

#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*/

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值