Python Graph 图表 数据结构

发布于 2022-02-10 12:59:03 字数 1705 浏览 1228 评论 0

基本概念

  • 无向图、有向图、加权图、加权有向图
  • 边(edge)、顶点(vertex),自环、平行边
  • 顶点的度数。子图。连通图
  • 树是一个无环连通图,连通图的生成树是它的一幅子图,它含有图中所有的顶点且是一棵树
  • 稀疏图、稠密图

无向图

首先要解决的问题就是使用什么样的数据结构来表示无向图,一种方式是使用邻接矩阵,即一个大小为v*v的矩阵,当i和j之间有边连接时,则Vij为true,这种方式带来的问题就是总是需要用V^2的空间大小来表示一张有V个顶点的图,当图过大时,开销就会很大。

一种比较好的方式是使用邻接表,即使用数组来表示。将顶点的编号 0,1,2... 作为数组的索引,数组中每个位置的元素存放一个链表,链表中存储了所有与该索引的顶点相连的顶点的索引,如图所示:

可以看出,使用这种方式,对于一幅图,可能有多种不同的邻接表来表示。对于一幅V个顶点和E条边的图,空间复杂度与V+E成正比,添加一条边的时间复杂度为常数,遍历一个顶点的所有边的时间复杂度与V的度数成正比。

参考

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

亚希

文章 0 评论 0

cyp

文章 0 评论 0

北漠

文章 0 评论 0

11223456

文章 0 评论 0

坠似风落

文章 0 评论 0

游魂

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文