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

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

邻接表及加权邻接字典

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

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

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

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

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 graph_python graph什么意思相关推荐

  1. python 一张图画多条线_Gnuplot.py在一张图上绘制多条线

    我目前正试图使用gnuplot py从文本文件中绘制多行.我可以分别绘制两条线,但当我试图在同一个图上绘制它们时,它只绘制一条线.在 这是我的代码:#!/usr/bin/env python impo ...

  2. Python广度优先查找和深度优先查找(内附python教程分享)

    https://www.toutiao.com/a6669563251212157447/ 图,特别是图的ADT(抽象数据类型)在计算机科学和数学领域是应用非常广泛的. 图基本认识 图模拟一组连接,假 ...

  3. python循环括号_Python for循环内括号语法

    所以我尝试将这个Python函数转换成Javascript.我不熟悉Python,所以有些语法对我来说很难加密.这是原始代码和我尝试的JS转换.我知道我解释错了,因为我现在所看到的是一个无限循环.在 ...

  4. python中的rt_TensorRT学习总结

    TensorRT是什么 建议先看看这篇https://zhuanlan.zhihu.com/p/35657027 深度学习 训练 部署 平常自学深度学习的时候关注的更多是训练的部分,即得到一个模型.而 ...

  5. Python性能分析入门——cProfile、可视化、逐行分析、内存分析

    文章目录 简介 cProfile PyCharm 可视化 安装 gprof2dot SnakeViz PyCallGraph 逐行分析 内存分析 内存堆分析 其他 遇到的坑 参考文献 简介 通过性能分 ...

  6. 三牛三虎过河问题--图的最短路径dijkstra算法--简单的Python实现

    问题:三头牛三只虎要过河,船需要一只动物来划,另外至多还能载一物,而只有一头牛和一只虎会划船,并且当虎的数量多于牛的数量时,虎要吃牛,请设计一个安全渡河方案,并使渡河次数尽量少. 我们用一个数组来表示 ...

  7. c语言调用graphviz_c语言分析函数调用关系图(call graph)的几种方法

    一.基于 Doxygen或 lxr 的API形式的文档系统. 二.基于CodeViz, CodeViz是<Understanding The Linux Virtual Memory Manag ...

  8. python算法完整教程专栏完整目录

    python算法完整教程专栏完整目录 专栏说明如下 专栏目录 专栏说明如下 内容:python算法完整教程 数量:692篇博文(2023年2月15日截止) 更新时间至:2023年2月15日(后续加上去 ...

  9. python解图片迷宫生成路径_在python中制作迷宫图

    嘿,我正在尝试使用Python中的字典制作图表.我正在使用一个包含迷宫的txt文件(b代表路径的墙壁)我正在尝试制作一个字典,列出迷宫中所有可能的移动(简单步骤,而不是完整路径).关于我应该从哪里开始 ...

最新文章

  1. 各种图论模型及其解答(转)
  2. 数据库被黑后留下的数据
  3. 哈希表(HASHTABLE)
  4. 使用Flask-Mail发送邮件
  5. c++中extern,static,const关键字的作用
  6. 【腾讯Bugly干货分享】Android Patch 方案与持续交付
  7. 计算机组装维修期末考试题,2014计算机组装维修期末考试题(1)
  8. 关于内置浏览器的问题
  9. 编程 态度目标_对目标持开放态度,从而推动事业发展
  10. 俗话说“肩挑四两为客,帮人一日为奴”,这是什么意思?
  11. GNU Radio 之 rtl-sdr
  12. Android 解决Dialog 样式的Activity 半透明背景失效问题
  13. python中的round
  14. 基于php的地铁查询系统,动手构建地铁关系网,实现最短路径查询
  15. 6.4.3 拓扑排序 番茄炒蛋工程
  16. excel单元格内回车换行
  17. 分治策略找第K小元素
  18. Codeforces 985A. Chess Placing(1ni)(水题)(div.2)
  19. OpenCV/kornia/Pillow/Halcon/NI Vision/MIL/*计算机视觉资料汇总
  20. Unity Shader-Command Buffer的使用(景深与描边效果重置版)

热门文章

  1. vue获取dom元素注意问题
  2. 苹果支付和ios安全 - 你需要知道的
  3. Carring data across redirect requests
  4. 设计模式学习笔记(八:迭代器模式)
  5. [转载]javascript创建对象的几种方式
  6. ​shell-7.shell 字符串的使用
  7. NSArray与NSString、NSData,NSDictionary与NSString、NSData 相互转化
  8. Windows Server 2012R2 DHCP故障转移(3)
  9. 深度解析ASP.NET2.0中的Callback机制
  10. pyWavelets工具包的安装及使用