NetworkX之Prim算法(实例讲解)


Posted in Python onDecember 22, 2017

引言

Prim算法与Dijkstra的最短路径算法类似,它采用贪心策略。算法开始先把图中权值最小的边添加到树T中,然后不断把权值最小的边E(E的一个端点在T中,另一个在G-T中)。当没有符合条件的E时算法结束,此时T就是G的一个最小生成树。

NetworkX是一款Python的软件包,用于创造、操作复杂网络,以及学习复杂网络的结构、动力学及其功能。 本文借助networkx.Graph类实现Prim算法。

正文

Prim算法的代码

Prim

NetworkX之Prim算法(实例讲解)

def prim(G, s):
 dist = {} # dist记录到节点的最小距离
 parent = {} # parent记录最小生成树的双亲表
 Q = list(G.nodes()) # Q包含所有未被生成树覆盖的节点
 MAXDIST = 9999.99 # MAXDIST表示正无穷,即两节点不邻接
 # 初始化数据
 # 所有节点的最小距离设为MAXDIST,父节点设为None
 for v in G.nodes():
  dist[v] = MAXDIST
  parent[v] = None
 # 到开始节点s的距离设为0
 dist[s] = 0
 # 不断从Q中取出“最近”的节点加入最小生成树
 # 当Q为空时停止循环,算法结束
 while Q:
  # 取出“最近”的节点u,把u加入最小生成树
  u = Q[0]
  for v in Q:
   if (dist[v] < dist[u]):
    u = v
  Q.remove(u)
  # 更新u的邻接节点的最小距离
  for v in G.adj[u]:
   if (v in Q) and (G[u][v]['weight'] < dist[v]):
    parent[v] = u
    dist[v] = G[u][v]['weight']
 # 算法结束,以双亲表的形式返回最小生成树
 return parent

测试数据

从~到 2 3 4 5 6 7 8
1 1.3 2.1 0.9 0.7 1.8 2.0 1.8
2 0.9 1.8 1.2 2.8 2.3 1.1
3 2.6 1.7 2.5 1.9 1.0
4 0.7 1.6 1.5 0.9
5 0.9 1.1 0.8
6 0.6 1.0
7 0.5

NetworkX之Prim算法(实例讲解)

测试代码

import matplotlib.pyplot as plt
import networkx as nx
g_data = [(1, 2, 1.3), (1, 3, 2.1), (1, 4, 0.9), (1, 5, 0.7), (1, 6, 1.8), (1, 7, 2.0), (1, 8, 1.8), (2, 3, 0.9), (2, 4, 1.8), (2, 5, 1.2), (2, 6, 2.8), (2, 7, 2.3), (2, 8, 1.1), (3, 4, 2.6), (3, 5, 1.7), (3, 6, 2.5), (3, 7, 1.9), (3, 8, 1.0), (4, 5, 0.7), (4, 6, 1.6), (4, 7, 1.5), (4, 8, 0.9), (5, 6, 0.9), (5, 7, 1.1), (5, 8, 0.8), (6, 7, 0.6), (6, 8, 1.0), (7, 8, 0.5)]
def draw(g):
 pos = nx.spring_layout(g)
 nx.draw(g, pos, \
   arrows=True, \
   with_labels=True, \
   nodelist=g.nodes(), \
   style='dashed', \
   edge_color='b', \
   width=2, \
   node_color='y', \
   alpha=0.5)
 plt.show()
g = nx.Graph()
g.add_weighted_edges_from(g_data)
tree = prim(g, 1)
mtg = nx.Graph()
mtg.add_edges_from(tree.items())
mtg.remove_node(None)
draw(mtg)

运行结果

NetworkX之Prim算法(实例讲解)

以上这篇NetworkX之Prim算法(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python字符串切片操作知识详解
Mar 28 Python
Python内置数据结构与操作符的练习题集锦
Jul 01 Python
python如何查看系统网络流量的信息
Sep 12 Python
python实现八大排序算法(1)
Sep 14 Python
使用Python &amp; Flask 实现RESTful Web API的实例
Sep 19 Python
tensorflow学习笔记之简单的神经网络训练和测试
Apr 15 Python
pandas读取csv文件,分隔符参数sep的实例
Dec 12 Python
Pandas 重塑(stack)和轴向旋转(pivot)的实现
Jul 22 Python
python基于三阶贝塞尔曲线的数据平滑算法
Dec 27 Python
Python+OpenCV实现将图像转换为二进制格式
Jan 09 Python
Kears 使用:通过回调函数保存最佳准确率下的模型操作
Jun 17 Python
Python Tkinter实例——模拟掷骰子
Oct 24 Python
Python实现控制台中的进度条功能代码
Dec 22 #Python
Python中的探索性数据分析(功能式)
Dec 22 #Python
Python反射用法实例简析
Dec 22 #Python
Python文本特征抽取与向量化算法学习
Dec 22 #Python
用Python实现KNN分类算法
Dec 22 #Python
Python数据拟合与广义线性回归算法学习
Dec 22 #Python
python 动态加载的实现方法
Dec 22 #Python
You might like
php下使用以下代码连接并测试
2008/04/09 PHP
基于php缓存的详解
2013/05/15 PHP
Laravel构建即时应用的一种实现方法详解
2017/08/31 PHP
Laravel 类和接口注入相关的代码
2019/10/15 PHP
ajaxControlToolkit AutoCompleteExtender的用法
2008/10/30 Javascript
跨浏览器开发经验总结(三)   警惕“IE依赖综合症”
2010/05/13 Javascript
Jquery颜色选择器ColorPicker实现代码
2012/11/14 Javascript
jquery检测input checked 控件是否被选中的方法
2014/03/26 Javascript
Js使用WScript.Shell对象执行.bat文件和cmd命令
2014/12/18 Javascript
在JS方法中返回多个值的方法汇总
2015/05/20 Javascript
jQuery插件pagewalkthrough实现引导页效果
2015/07/05 Javascript
js阻止浏览器默认行为的简单实例
2016/05/15 Javascript
JS工作中的小贴士之”闭包“与事件委托的”阻止冒泡“
2016/06/16 Javascript
高效Web开发的10个jQuery代码片段
2016/07/22 Javascript
基于JS实现回到页面顶部的五种写法(从实现到增强)
2016/09/03 Javascript
一篇看懂vuejs的状态管理神器 vuex状态管理模式
2017/04/20 Javascript
jQuery实现按比例缩放图片的方法
2017/04/29 jQuery
Angular.Js中过滤器filter与自定义过滤器filter实例详解
2017/05/08 Javascript
详解angularJS+Ionic移动端图片上传的解决办法
2017/09/13 Javascript
vue 1.x 交互实现仿百度下拉列表示例
2017/10/21 Javascript
Vue项目部署的实现(阿里云+Nginx代理+PM2)
2019/03/26 Javascript
AngularJs的$http发送POST请求,php无法接收Post的数据问题及解决方案
2020/08/13 Javascript
跟老齐学Python之玩转字符串(1)
2014/09/14 Python
Python机器学习之scikit-learn库中KNN算法的封装与使用方法
2018/12/14 Python
python匿名函数lambda原理及实例解析
2020/02/07 Python
Python基于tkinter canvas实现图片裁剪功能
2020/11/05 Python
CSS 3.0 结合video视频实现的创意开幕效果
2020/06/01 HTML / CSS
宏碁西班牙官网:Acer西班牙
2021/01/08 全球购物
前处理组长岗位职责
2014/03/01 职场文书
餐厅总厨求职信
2014/03/04 职场文书
《特殊的葬礼》教学反思
2014/04/27 职场文书
优质服务演讲稿
2014/05/14 职场文书
班组长安全工作职责
2014/07/15 职场文书
2014员工聘用协议书(最新版)
2014/11/24 职场文书
部门经理助理岗位职责
2015/04/13 职场文书
教你怎么用Python实现多路径迷宫
2021/04/29 Python