算法设计和分析(Prim算法构建最小生成树)
问题:
给定无向图G(N,M)表明图G有N个顶点,M条边,通过Prim算法构造一个最小生成树
分析:

算法流程:

构造好的最小生成树就是step6
运行代码:
#include<cstdio>
#include<string.h>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<vector>
#include<queue>
#include<set>
#include<map>
#include<cctype>
#include<stack>
#define ios ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define mem(a,x) memset(a,x,sizeof(a))
#define lson rt<<1,l,mid
#define rson rt<<1|1,mid + 1,r
#define P pair<int,int>
#define ull unsigned long long
using namespace std;
typedef long long ll;
const int maxn = ;
const ll mod = ;
const int inf = 0x3f3f3f3f;
const long long INF = 0x3f3f3f3f3f3f3f3f;
const double eps = 1e-; int n, m; // 假设有n个点,m条边
int edge[maxn][maxn]; // 用邻接矩阵来存图
int vis[maxn]; // 记录某点是否加入最小生成树中
int dist[maxn]; // 记录最小生成树中每一个点邻接的最短边
int father[maxn]; // 记录某点的父亲节点,记录构成最小生成树的边
int main()
{ scanf("%d %d", &n, &m);
memset(edge, inf, sizeof edge); // 将临界矩阵初始化为inf ,edge[u][v] == inf 代表u和v不连通
for (int i = ; i <= n; ++i) // 将数据进行初始化
{
vis[i] = false;
father[i] = -;
dist[i] = inf;
edge[i][i] = ;
}
for (int i = ; i <= m; ++i)
{
int u, v,val;
scanf("%d %d %d", &u, &v,&val); // 获取边的起点、终点和权值
edge[u][v] = min(val , edge[u][v]);
edge[v][u] = min(val , edge[v][u]); // 用邻接矩阵存图 , 对于起点和终点相同的边仅保留最小值即可
}
vis[] = true; // 将1号点添加进最小生成树中,作为树根
for (int i = ; i <= n; ++i)
{
dist[i] = edge[][i];
father[i] = ;
}
father[] = -; // 将树根的父亲节点设为-1
for (int i = ; i <= n; ++i)
{
int v = -;
int tmp = inf;
for (int j = ; j <= n; ++j) // 在最小生成树之外寻找最短路径
{
if (!vis[j] && dist[j] < tmp)
{
v = j;
tmp = dist[j];
}
}
vis[v] = true; // 将寻找到的最短路径的终点加入最小生成树中
for (int j = ; j <= n; ++j)
{
if (!vis[j] && edge[v][j] < dist[j]) // 在有新的点加入最小生成树之后,要更新dist中的值
{
dist[j] = edge[v][j];
father[j] = v;
}
}
}
int sum = ;
for (int i = ; i <= n; ++i) sum += dist[i]; //输出最小生成树的权值和,以及构成最小生成树的边
printf("最小生成树的权值是:%d\n", sum);
printf("构成最小生成树的边为:\n");
for (int i = ; i <= n; ++i)
{
if (father[i] != -)
{
printf("%d %d\n", father[i], i);
}
}
return ;
} /*
6 9
1 5 1
1 6 2
1 2 3
2 6 4
2 3 5
3 6 6
3 4 7
4 6 8
4 5 9 样例 */
Prim
算法设计和分析(Prim算法构建最小生成树)的更多相关文章
- 『嗨威说』算法设计与分析 - 贪心算法思想小结(HDU 2088 Box of Bricks)
本文索引目录: 一.贪心算法的基本思想以及个人理解 二.汽车加油问题的贪心选择性质 三.一道贪心算法题点拨升华贪心思想 四.结对编程情况 一.贪心算法的基本思想以及个人理解: 1.1 基本概念: 首先 ...
- 【技术文档】《算法设计与分析导论》R.C.T.Lee等·第7章 动态规划
由于种种原因(看这一章间隔的时间太长,弄不清动态规划.分治.递归是什么关系),导致这章内容看了三遍才基本看懂动态规划是什么.动态规划适合解决可分阶段的组合优化问题,但它又不同于贪心算法,动态规划所解决 ...
- 算法设计与分析 - AC 题目 - 第 5 弹(重复第 2 弹)
PTA-算法设计与分析-AC原题 - 最大子列和问题 (20分) 给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni+, ..., Nj },其中 ≤i ...
- 算法设计与分析 - AC 题目 - 第 2 弹
PTA-算法设计与分析-AC原题7-1 最大子列和问题 (20分)给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni+1, ..., Nj },其中 1 ...
- 算法设计与分析-Week12
题目描述 You are given coins of different denominations and a total amount of money amount. Write a func ...
- 算法设计与分析基础 (Anany Levitin 著)
第1章 绪论 1.1 什么是算法 1.2 算法问题求解基础 1.2.1 理解问题 1.2.2 了解计算设备的性能 1.2.3 在精确解法和近似解法之间做出选择 1.2.4 算法的设计技术 1.2.5 ...
- 南大算法设计与分析课程复习笔记(1) L1 - Model of computation
一.计算模型 1.1 定义: 我们在思考和处理算法的时候是机器无关.实现语言无关的.所有的算法运行在一种“抽象的机器”之上,这就是计算模型. 1.2 种类 图灵机是最有名的计算模型,本课使用更简单更合 ...
- 算法设计与分析(李春保)练习题答案v1
1.1第1 章─概论 1.1.1练习题 1.下列关于算法的说法中正确的有(). Ⅰ.求解某一类问题的算法是唯一的 Ⅱ.算法必须在有限步操作之后停止 Ⅲ.算法的每一步操作必须是明确的,不能有歧义或含义模 ...
- 算法设计与分析 - 李春葆 - 第二版 - pdf->word v3
1.1 第1章─概论 练习题 . 下列关于算法的说法中正确的有( ). Ⅰ.求解某一类问题的算法是唯一的 Ⅱ.算法必须在有限步操作之后停止 Ⅲ.算法的每一步操作必须是明确的,不能有歧义或含义模糊 Ⅳ. ...
随机推荐
- Matplotlib 图形绘制
章节 Matplotlib 安装 Matplotlib 入门 Matplotlib 基本概念 Matplotlib 图形绘制 Matplotlib 多个图形 Matplotlib 其他类型图形 Mat ...
- PAT (Advanced Level) 1144~1147:1145Hash二次探查 1146拓扑排序 1147堆
1144 The Missing Number(20 分) 题意:给定N个数的序列,输出不在序列中的最小的正整数. 分析: 1.给定的N个数可能为正,可能为负,可能重复. 2.由于N≤105,所 ...
- Ubuntu 19.10将使用GCC 9作为默认编译器
作为我们这一周期一直期待的变化,Ubuntu 19.10升级到GCC 9作为GCC 8的默认系统编译器. Ubuntu 19.10(和Ubuntu 20.04 LTS)将使用GCC 9 stable作 ...
- linux 常用文件命令记录
服务开启命令 service 服务 start/stop/stauts 查看ip ifconfig 清屏 clear 显示当前所在位置 pwd 切换目录 cd 查看所有文件(包括隐藏) ls -a ...
- 二进制枚举之被RE完虐的我的一天
记录一道学长们说有点难度的题目 好好玩啊这道题 ACM程序设计大赛是大学级别最高的脑力竞赛,素来被冠以"程序设计的奥林匹克"的尊称.大赛至今已有近40年的历史,是世界范围内历史最悠 ...
- face_recognition人脸识别
对亚洲人识别准确度有点差,具体安装移步:https://www.cnblogs.com/ckAng/p/10981025.html 更多操作移步:https://github.com/ageitgey ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 字体图标(Glyphicons):glyphicon glyphicon-remove
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- Problem C Updating a Dictionary
Problem C Updating a Dictionary In this problem, a dictionary is collection of key-value pairs, ...
- 安装phpmyadmin数据可视化
1.下载压缩包,并且解压 cd /usr/local/src wget https://files.phpmyadmin.net/phpMyAdmin/4.9.4/phpMyAdmin-4.9.4-a ...
- 初玩PLSQL连接 Oracle
1. 官网下载合适的[Instant Client] https://www.oracle.com/database/technologies/instant-client/winx64-64-dow ...