图的最小生成树 Prim算法 C++实现

/*
* File name  : graph_cmst_prim.cpp
* Function   : 图的最小生成树 Prim算法  C++实现
* Created on : 2016年6月8日
* Author     : beijiwei@qq.com
* Copyright  : 欢迎大家和我一起交流学习,转载请保持源文件的完整性。
任何单位和个人不经本人允许不得用于商业用途

input:
6 9
2 4 11
3 5 13
4 6 3
5 6 4
2 3 6
4 5 7
1 2 1
3 4 9
1 3 2


*/
#include <cstdio>
#include <iostream>
#pragma warning(disable:4996)

using namespace std;


#define M 20
#define INF 99999;

int edge_map[M][M];
int dis[M];
int mark[M];
int path[M];


int vertex_count = 0;
int weight_sum = 0;

int main(int argc, char** argv)
{
    freopen("input.txt", "r", stdin);
    int vertex_num, edge_num;
    cin >> vertex_num >> edge_num;

    for (int i = 1; i <= vertex_num; i++)//初始化邻接矩阵
    {
        for (int j = 1; j <= vertex_num; j++)
        {
            if (i == j)
                edge_map[i][j] = 0;
            else
                edge_map[i][j] = INF;
        }
    }

    for (int i = 1; i <= edge_num; i++)//读入边
    {
        int start, end, weight;
        cin >> start >> end >> weight;
        edge_map[start][end] = weight;
        edge_map[end][start] = weight;//无向图
    }

    for (int i = 1; i <= vertex_num; i++)//初始化dis[],这里是一号顶点到其他顶点的距离
    {
        dis[i] = edge_map[1][i];
        mark[i] = 0;
        path[i] = 0;
    }

    mark[1] = 1;
    vertex_count++;
    path[0] = 1;

    while (vertex_count <= vertex_num)
    {
        int min = INF;
        int k = 0;
        for (int i = 1; i <= vertex_num; i++)
        {
            if (mark[i] == 0 && min > dis[i])
            {
                min = dis[i];
                k = i;
            }
        }
        if (k == 0)
            break;
        mark[k] = 1;
        path[vertex_count] = k;
        vertex_count++;
        weight_sum += dis[k];

        for (int i = 1; i <= vertex_num; i++)
        {
            if (mark[i] == 0 && dis[i] > edge_map[k][i])
            {
                dis[i] = edge_map[k][i];
            }
        }
    }

    cout << "最短路径是: " << weight_sum << endl;
    for (int i = 0; i < vertex_num; i++)
    {
        cout << "顶点是: " << path[i] << endl;
    }


    return 0;
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值