Python数据结构与算法之图结构(Graph)实例分析


Posted in Python onSeptember 05, 2017

本文实例讲述了Python数据结构与算法之图结构(Graph)。分享给大家供大家参考,具体如下:

图结构(Graph)——算法学中最强大的框架之一。树结构只是图的一种特殊情况。

如果我们可将自己的工作诠释成一个图问题的话,那么该问题至少已经接近解决方案了。而我们我们的问题实例可以用树结构(tree)来诠释,那么我们基本上已经拥有了一个真正有效的解决方案了。

邻接表及加权邻接字典

对于图结构的实现来说,最直观的方式之一就是使用邻接列表。基本上就是针对每个节点设置一个邻接列表。下面我们来实现一个最简单的:假设我们现有 n 个节点,编号分别为 0, …, n-1.

节点当然可以是任何对象,可被赋予任何标签或名称。但使用 0, …, n-1 区间内的整数来实现的话,会简单许多。因为如果我们能用数字来代表节点,我们索引起来显然要方便许多。

然后,每个邻接(邻居)列表都只是一个数字列表,我们可以将它们编入一个大小为 n 的主列表,并用节点编号对其进行索引。由于这些列表内的节点的顺序是任意的,所以,实际上,我们是使用列表来实现邻接集(adjacency sets)。这里之所以还是使用列表这个术语,主要是因为传统。幸运的是,Python 本身就提供独立的 set 类型。

我们以下图为例,说明图结构的各种表示方法当我们在执行与图相关的工作时,需要反复遵从一个主题思想,即一个图的最佳表示方法应该取决于我们要用它来做什么):

Python数据结构与算法之图结构(Graph)实例分析

a, b, c, d, e, f, g, h = range(8)
N = [
  {b, c, d, e, f},
  {c, e},
  {d},
  {e},
  {f},
  {c, g, h},
  {f, h},
  {f, g}
]

在图论中,N(v) 代表的是 v 的邻居节点集

>>> b in N[a]         # neighborhood membership
True
>>> len(N[f])         # out-degree:出度
3

加权邻接字典

使用 dict 类型来代替 set 或 list 来表示邻接集。在 dict 类型中,每个邻居节点都会有一个键和一个额外的值,用于表示与其邻居节点(或出边)之间的关联性,如边的权重。

a, b, c, d, e, f, g, h = range(8)
N = [
  {b:2, c:1, d:3, e:9, f:4},
  {c:4, e:4},
  {d:8},
  {e:7},
  {f:5},
  {c:2, g:2, h:2},
  {f:1, h:6},
  {f:9, g:8}
]

客户端调用:

>>> b in N[a]         # neighborhood membership
True
>>> len(N[f])         # out-degree
3
>>> N[a][b]          # Edge weight for (a, b)
2

邻接矩阵

邻接矩阵是图的另一种表示方法,这种表示方法的主要不同在于,它不再列出每个节点的所有邻居节点。

a, b, c, d, e, f, g, h = range(8)
N =[
  [0, 1, 1, 1, 1, 1, 0, 0],
  [0, 0, 1, 0, 1, 0, 0, 0],
  [0, 0, 0, 1, 0, 0, 0, 0],
  [0, 0, 0, 0, 1, 0, 0, 0],
  [0, 0, 0, 0, 0, 1, 0, 0],
  [0, 0, 1, 0, 0, 0, 1, 1],
  [0, 0, 0, 0, 0, 1, 0, 1],
  [0, 0, 0, 0, 0, 1, 1, 0],
]

关于邻接矩阵:

(1)主对角线为自己到自己,为0
(2)行和为出度
(3)列和为入度

更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
详解Python中的序列化与反序列化的使用
Jun 30 Python
Python代码实现KNN算法
Dec 20 Python
Python装饰器用法实例总结
Feb 07 Python
python 匹配url中是否存在IP地址的方法
Jun 04 Python
用uWSGI和Nginx部署Flask项目的方法示例
May 05 Python
利用python-pypcap抓取带VLAN标签的数据包方法
Jul 23 Python
Python queue队列原理与应用案例分析
Sep 27 Python
基于python-pptx库中文文档及使用详解
Feb 14 Python
python 追踪except信息方式
Apr 25 Python
基于Python 的语音重采样函数解析
Jul 06 Python
python遍历路径破解表单的示例
Nov 21 Python
python3+PyQt5+Qt Designer实现界面可视化
Jun 10 Python
利用Python将时间或时间间隔转为ISO 8601格式方法示例
Sep 05 #Python
python进程管理工具supervisor的安装与使用教程
Sep 05 #Python
基于Django模板中的数字自增(详解)
Sep 05 #Python
用python结合jieba和wordcloud实现词云效果
Sep 05 #Python
python基础_文件操作实现全文或单行替换的方法
Sep 04 #Python
python 生成器协程运算实例
Sep 04 #Python
python 文件操作删除某行的实例
Sep 04 #Python
You might like
PHP简单实现冒泡排序的方法
2016/12/26 PHP
php识别翻转iphone拍摄的颠倒图片
2018/05/17 PHP
让JavaScript 轻松支持函数重载 (Part 1 - 设计)
2009/08/04 Javascript
JavaScript 提升运行速度之循环篇 译文
2009/08/15 Javascript
使用javascript将时间转换成今天,昨天,前天等格式
2015/06/25 Javascript
javascript中sort() 方法使用详解
2015/08/30 Javascript
探讨JavaScript语句的执行过程
2016/01/28 Javascript
Javascript 字符串模板的简单实现
2016/02/13 Javascript
webpack实践之DLLPlugin 和 DLLReferencePlugin的使用教程
2019/06/10 Javascript
深入解读Node.js中的koa源码
2019/06/17 Javascript
js数据类型转换与流程控制操作实例分析
2019/12/18 Javascript
JS数组的高级使用方法示例小结
2020/03/14 Javascript
javascript事件循环event loop的简单模型解释与应用分析
2020/03/14 Javascript
vue各种事件监听实例(小结)
2020/06/24 Javascript
[02:32]DOTA2亚洲邀请赛 C9战队出场宣传片
2015/02/07 DOTA
Python ORM框架SQLAlchemy学习笔记之数据查询实例
2014/06/10 Python
Python中使用Counter进行字典创建以及key数量统计的方法
2018/07/06 Python
python打印直角三角形与等腰三角形实例代码
2019/10/20 Python
Python爬取腾讯视频评论的思路详解
2019/12/19 Python
Python logging日志模块 配置文件方式
2020/07/12 Python
CSS3结构性伪类选择器九种写法
2012/04/18 HTML / CSS
基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
2014/06/11 HTML / CSS
京东奢侈品:全球奢侈品牌
2018/03/17 全球购物
荷兰演唱会和体育比赛订票网站:viagogo荷兰
2018/04/08 全球购物
澳大利亚在线家具、灯饰和家居装饰店:LivingStyles
2018/11/20 全球购物
Hawes & Curtis官网:英国经典品牌
2019/07/27 全球购物
捷克母婴用品购物网站:Feedo.cz
2020/12/28 全球购物
腾讯技术类校园招聘笔试试题
2014/05/06 面试题
大学专科生推荐信范文
2013/11/23 职场文书
会计专业的自荐信
2013/12/12 职场文书
总经理秘书工作职责
2013/12/26 职场文书
应用艺术专业个人的自我评价
2014/01/03 职场文书
红色故事演讲稿
2014/05/22 职场文书
干部作风整顿自我剖析材料和整改措施
2014/09/18 职场文书
机动车交通事故协议书
2015/01/29 职场文书
Django框架中模型的用法
2022/06/10 Python