码迷,mamicode.com
首页 > 编程语言 > 详细

最小生成树 - 普利姆算法

时间:2016-04-19 16:57:05      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:

#include<cstdlib>
#include<cstdio>
#include<cstring>
#define MAXVEX 100
#define INFINITY 65535

typedef struct {
    char vexs[MAXVEX];
    int arc[MAXVEX][MAXVEX];
    int numVextexes,numEdges;
}MGraph;

void CreateGraph(MGraph *G){
    int i,j,k,w;
    printf("输入顶点数和边数:\n");
    scanf("%d %d",&G->numVextexes,&G->numEdges);
    for(i=0;i<G->numVextexes;i++){
        scanf(&G->vexs[i]);
    }
    for(i=0;i<G->numVextexes;i++){
        for(j=0;j<G->numVextexes;j++){
            G->arc[i][j] = INFINITY;
        }
    }
    printf(" G->numEdges = %d \n",G->numEdges);
    for(k=0;k<G->numEdges;k++){
      //  printf(" k = %d \n",k);
         printf("输入边(Vi,Vj)上的下标1,和下标j和权w:\n");
        scanf("%d %d %d",&i,&j,&w);
        G->arc[j][i] = G->arc[i][j] = w;
    }
    return;
}
void MiniSpanTree_Prim(MGraph G){
    int min,i,j,k,p;
    int adjvex[MAXVEX]; //保存相关顶点下标
    int lowcost[MAXVEX];    //==========这个自己亲自多跑跑代码就懂了,不要懵,不要乱就能得出规律和结论 
    lowcost[0] = 0;
    adjvex[0] = 0;
    for(i=1;i<G.numVextexes;i++){
        lowcost[i] = G.arc[0][i];
        adjvex[i] = 0;
    }
    for(i=1;i<G.numVextexes;i++){
        min = INFINITY;
        j = 1;k = 0;
       // for(p=0;p<G.numVextexes;p++)	printf("%d  ",adjvex[p]);
        while(j<G.numVextexes){
            if(lowcost[j] != 0 && lowcost[j] < min){
                min = lowcost[j];
                k = j;
            }
            j++;
        }
       // for(p=0;p<G.numVextexes;p++)	printf("%d  ",lowcost[p]);
        printf("\n(%d,%d)\n",adjvex[k],k);
        lowcost[k] = 0;
        for(j = 0;j< G.numVextexes;j++){
            if(lowcost[j]!=0 && G.arc[k][j] < lowcost[j]){
                lowcost[j] = G.arc[k][j];
                adjvex[j] = k;
            }
        }
    }
    return;
}
int main(){
    MGraph G;
    CreateGraph(&G);
    MiniSpanTree_Prim(G);
    return 0;
}

  

最小生成树 - 普利姆算法

标签:

原文地址:http://www.cnblogs.com/zhuozhuo/p/5408531.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!