图的理解:存储结构与邻接矩阵

存储结构

要存储一个图,我们知道图既有结点,又有边,对于有权图来说,每条边上还带有权值。常用的图的存储结构主要有以下二种:

  • 邻接矩阵
  • 邻接表

邻接矩阵

我们知道,要表示结点,我们可以用一个一维数组来表示,然而对于结点和结点之间的关系,则无法简单地用一维数组来表示了,我们可以用二维数组来表示,也就是一个矩阵形式的表示方法。

我们假设A是这个二维数组,那么A中的一个元素aij不仅体现出了结点vi和结点vj的关系,而且aij的值正可以表示权值的大小。

以下是一个无向图的邻接矩阵表示示例:

从上图我们可以看到,无向图的邻接矩阵是对称矩阵,也一定是对称矩阵。且其左上角到右下角的对角线上值为零(对角线上表示的是相同的结点)

有向图的邻接矩阵是怎样的呢?

对于带权图,aij的值可用来表示权值的大小,上面两张图是不带权的图,因此它们值都是1。

邻接表

我们知道,图的邻接矩阵存储方法用的是一个n*n的矩阵,当这个矩阵是稠密的矩阵(比如说当图是完全图的时候),那么当然选择用邻接矩阵存储方法。
可是如果这个矩阵是一个稀疏的矩阵呢,这个时候邻接表存储结构就是一种更节省空间的存储结构了。
对于上文中的无向图,我们可以用邻接表来表示,如下:

每一个结点后面所接的结点都是它的邻接结点。

邻接矩阵与邻接表的比较

当图中结点数目较小且边较多时,采用邻接矩阵效率更高。
当节点数目远大且边的数目远小于相同结点的完全图的边数时,采用邻接表存储结构更有效率。

时间: 2024-08-24 13:48:15

图的理解:存储结构与邻接矩阵的相关文章

图的存储结构(邻接矩阵)

图的存储结构(邻接矩阵) 让编程改变世界 Change the world by program 图的存储结构 图的存储结构相比较线性表与树来说就复杂很多. 我们回顾下,对于线性表来说,是一对一的关系,所以用数组或者链表均可简单存放.树结构是一对多的关系,所以我们要将数组和链表的特性结合在一起才能更好的存放. 那么我们的图,是多对多的情况,另外图上的任何一个顶点都可以被看作是第一个顶点,任一顶点的邻接点之间也不存在次序关系. 我们仔细观察以下几张图,然后深刻领悟一下: 因为任意两个顶点之间都可能

理解存储结构1

存储结构 Extent:表空间中的基本单位 表空间区的管理方式 LMT & DMT LMT有两种方式控制区的大小 autoallocate # 自动分配 uniform # 由DBA指定每个区的大小 那么显然,当创建表空间时使用uniform size,每个区的大小一样,都为设定好的uniform size 而autoallocate是默认的分配方式,由oracle去管理,决定区的大小,也就是一个区有多少个块 那么我们就创建一个统一区大小表空间 create tablespace fan dat

存储结构与邻接矩阵,深度优先和广度优先遍历及Java实现

如果看完本篇博客任有不明白的地方,可以去看一下<大话数据结构>的7.4以及7.5,讲得比较易懂,不过是用C实现 下面内容来自segmentfault 存储结构 要存储一个图,我们知道图既有结点,又有边,对于有权图来说,每条边上还带有权值.常用的图的存储结构主要有以下二种: 邻接矩阵 邻接表 邻接矩阵 我们知道,要表示结点,我们可以用一个一维数组来表示,然而对于结点和结点之间的关系,则无法简单地用一维数组来表示了,我们可以用二维数组来表示,也就是一个矩阵形式的表示方法. 我们假设A是这个二维数组

图总结之存储结构代码详解

一.图的存储结构 1.1 邻接矩阵 图的邻接矩阵存储方式是用两个数组来表示图.一个一维数组存储图中顶点信息,一个二维数组(邻接矩阵)存储图中的边或弧的信息. 设图G有n个顶点,则邻接矩阵是一个n*n的方阵,定义为: 看一个实例,下图左就是一个无向图. 从上面可以看出,无向图的边数组是一个对称矩阵.所谓对称矩阵就是n阶矩阵的元满足aij = aji.即从矩阵的左上角到右下角的主对角线为轴,右上角的元和左下角相对应的元全都是相等的. 从这个矩阵中,很容易知道图中的信息. (1)要判断任意两顶点是否有

图的存储结构:邻接矩阵(邻接表)&amp;链式前向星

[概念]疏松图&稠密图: 疏松图指,点连接的边不多的图,反之(点连接的边多)则为稠密图. Tips:邻接矩阵与邻接表相比,疏松图多用邻接表,稠密图多用邻接矩阵. 邻接矩阵: 开一个二维数组graph[ ][ ]来记录图中点a与点b之间是否连通,初始化为0(或者-1之类的看情况):如果图中有可忽略的重边(如 只需重边中的最小边或最大边),则保存需要的那条边的边权,但如果有无法忽略的重边,就一定不要用邻接矩阵. int graph[MAXN][MAXN]; void graphInit() { me

图 - 存储结构之邻接矩阵

图的邻接矩阵(Adjacency Matrix)存储方式是用两个数组来表示图.一个一维的数组存储图中顶点信息,一个二维数组(称为邻接矩阵)存储图中的边或弧的信息. 设图G有n个顶点,则邻接矩阵是一个n*n的方阵,定义为: 我们来看一个实例,图7-4-2的左图就是一个无向图. 我们再来看一个有向图样例,如图7-4-3所示的左图. 在图的术语中,我们提到了网的概念,也就是每条边上都带有权的图叫做网.那些这些权值就需要保存下来. 设图G是网图,有n个顶点,则邻接矩阵是一个n*n的方阵,定义为: 如图7

图的常用存储结构

一.邻接矩阵 邻接矩阵是简单的也是比较常用的一种表示图的数据结构,对于一个有N个点的图,需要一个N*N的矩阵,这个矩阵的i行第j列的数值表示点vi到点vj的距离.邻接矩阵需要初始化,map[i][i] = 0;map[i][j] = INF(i != j),对于每组读入的数据vi,vj,w(vi为边的起点,vj为边的终点,w为边的权值),赋值map[vi][vj] = w,另外邻接矩阵的值和边的输入顺序无关. 对于邻接矩阵来说,初始化需要O(n^2)的时间,建图需要O(m),所以总时间复杂度是O

Nutch中Web图基本类型和存储结构

类Node表示Web图中节点,基本信息包括:入链数.出链数.入链分数和元数据.出链分数通过入链分数除以出链数得到. 类LinkDatum表示Web图中链接,基本信息包括:链接.锚文本.分数.时间戳和链接类型(出链或入链). 类LinkNode表示链接节点,包括链接和Node两部分. 类LoopSet表示链接构成的环,包含环中的链接集合. Web图由抓取的段(主要是parse-data,可选包括crawl-fetch)生成,包括三部分:出链数据库.入链数据库和节点库. 设Web图所在目录为w,则:

理解存储结构2

接上篇http://blog.csdn.net/ashic/article/details/44117867 上篇中我们dump出了L1 L2 L3块,现在来了解一下它们中包含的信息 内容 注释 L1 FIRST LEVEL BITMAP BLOCK L2 SECOND LEVEL BITMAP BLOCK L3(段头) PAGETABLE SEGMENT HEADER 通过上面的表格再去看Dump文件我们可以很清楚的发现 在这个uniform size 1M的表空间中,一个区中又两个L1块,1