数据结构图论部分.ppt

上传人:wuy****n92 文档编号:64357617 上传时间:2022-11-29 格式:PPT 页数:191 大小:3.29MB
返回 下载 相关 举报
数据结构图论部分.ppt_第1页
第1页 / 共191页
数据结构图论部分.ppt_第2页
第2页 / 共191页
点击查看更多>>
资源描述

《数据结构图论部分.ppt》由会员分享,可在线阅读,更多相关《数据结构图论部分.ppt(191页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、Data StructureData Structure第七章第七章 图图1008651011/29/20221Data StructureData Structureq学习目标学习目标v领会领会图的类型定义图的类型定义。v熟悉熟悉图的各种存储结构图的各种存储结构及其构造算法,了解各种存储结构的特点及其构造算法,了解各种存储结构的特点及其及其选用原则选用原则。v熟练掌握图的两种熟练掌握图的两种遍历遍历算法。算法。v理解各种图的理解各种图的应用问题的算法应用问题的算法。q重点和难点重点和难点v重点:图的各种应用问题的算法都比较经典,注意重点:图的各种应用问题的算法都比较经典,注意理解各种图的理解

2、各种图的算法及其应用场合算法及其应用场合。11/29/20222Data StructureData Structureq知识点知识点v图的类型定义图的类型定义v图的存储表示图的存储表示v图的深度优先搜索遍历和广度优先搜索遍历图的深度优先搜索遍历和广度优先搜索遍历v无向网的最小生成树无向网的最小生成树v拓扑排序拓扑排序v关键路径关键路径v最短路径最短路径11/29/20223Data StructureData Structure欧拉欧拉17071707年出生在瑞士的巴塞尔城,年出生在瑞士的巴塞尔城,1919岁开始发岁开始发表论文,直到表论文,直到7676岁。几乎每一个数学领域都可以岁。几乎每

3、一个数学领域都可以看到欧拉的名字,从初等几何的欧拉线,多面体看到欧拉的名字,从初等几何的欧拉线,多面体的欧拉定理,立体解析几何的欧拉变换公式,四的欧拉定理,立体解析几何的欧拉变换公式,四次方程的欧拉解法到数论中的欧拉函数,微分方次方程的欧拉解法到数论中的欧拉函数,微分方程的欧拉方程,级数论的欧拉常数,变分学的欧程的欧拉方程,级数论的欧拉常数,变分学的欧拉方程,复变函数的欧拉公式等等。据统计他那拉方程,复变函数的欧拉公式等等。据统计他那不倦的一生,共写下了不倦的一生,共写下了886886本书籍和论文,其中本书籍和论文,其中分析、代数、数论占分析、代数、数论占40%40%,几何占,几何占18%18

4、%,物理和,物理和力学占力学占28%28%,天文学占,天文学占11%11%,弹道学、航海学、,弹道学、航海学、建筑学等占建筑学等占3%3%。1733 1733年,年仅年,年仅2626岁的欧拉担任岁的欧拉担任了彼得堡科学院数学教授。了彼得堡科学院数学教授。17411741年到柏林担任科年到柏林担任科学院物理数学所所长,直到学院物理数学所所长,直到17661766年,重回彼得堡,年,重回彼得堡,没有多久,完全失明。欧拉在数学上的建树很多,没有多久,完全失明。欧拉在数学上的建树很多,对著名的哥尼斯堡七桥问题的解答开创了图论的对著名的哥尼斯堡七桥问题的解答开创了图论的研究。研究。图论图论欧拉欧拉11/

5、29/20224Data StructureData Structure能否从某个地方出发,穿过所有的桥仅一次能否从某个地方出发,穿过所有的桥仅一次后再回到出发点?后再回到出发点?哥尼斯堡七桥问题哥尼斯堡七桥问题 11/29/20225Data StructureData StructureCADB七七桥问题桥问题的的图图模型模型欧拉回路的判定规则:欧拉回路的判定规则:1.如果通奇数桥的地方多于如果通奇数桥的地方多于两个,则不存在欧拉回路;两个,则不存在欧拉回路;2.如果只有两个地方通奇数如果只有两个地方通奇数桥,可以从这两个地方之一桥,可以从这两个地方之一出发,找到欧拉回路;出发,找到欧拉回

6、路;3.如果没有一个地方是通奇如果没有一个地方是通奇数桥的,则无论从哪里出发,数桥的,则无论从哪里出发,都能找到欧拉回路。都能找到欧拉回路。11/29/20226Data StructureData Structure图的定义图的定义图的定义图的定义图是由图是由顶点顶点的的有穷非空有穷非空集合和顶点之间集合和顶点之间边边的集合组的集合组成,通常表示为:成,通常表示为:G=(V,E)其中:其中:G表示一个图,表示一个图,V是图是图G中顶点的集合,中顶点的集合,E是是图图G中顶点之间边的集合。中顶点之间边的集合。在线性表中,元素个数可以为零,称为空表;在线性表中,元素个数可以为零,称为空表;在树中

7、,结点个数可以为零,称为空树;在树中,结点个数可以为零,称为空树;在图中,顶点个数不能为零,但可以没有边。在图中,顶点个数不能为零,但可以没有边。7.1 7.1 7.1 7.1 图的定义和术语图的定义和术语图的定义和术语图的定义和术语11/29/20227Data StructureData Structureq线性表线性表v每个数据元素只有一个直接前驱和一个直接后继。每个数据元素只有一个直接前驱和一个直接后继。q树形结构树形结构v每个数据元素只有一个直接前驱,但可能有多个直接后继。每个数据元素只有一个直接前驱,但可能有多个直接后继。q图形结构图形结构v每个数据元素可能有多个直接前驱和多个直接

8、后继。每个数据元素可能有多个直接前驱和多个直接后继。图是比线性表和树复杂的数据结构,广泛应用于语图是比线性表和树复杂的数据结构,广泛应用于语言学、逻辑学、物理、化学等领域。言学、逻辑学、物理、化学等领域。11/29/20228Data StructureData Structure如如果果图图的的任任意意两两个个顶顶点点之之间间的的边边都都是是无向边,则称该图为无向边,则称该图为无向图无向图。若顶点若顶点vi和和vj之间的边没有方向,则之间的边没有方向,则称这条边为称这条边为无向边无向边,表示为,表示为(vi,vj)。若从顶点若从顶点vi到到vj的边有方向,则称这的边有方向,则称这条边为条边为

9、有向边有向边,表示为,表示为。如如果果图图的的任任意意两两个个顶顶点点之之间间的的边边都都是是有向边,则称该图为有向边,则称该图为有向图有向图。V1V2V3V4V5V1V2V3V4图的基本术语图的基本术语11/29/20229Data StructureData Structure简单图:简单图:在图中,若不存在顶点到其自身的边,且同在图中,若不存在顶点到其自身的边,且同一条边不重复出现一条边不重复出现。V3V4V5V1V2V3V4V5V1V2非简单图非简单图 非简单图非简单图 简单图简单图V1V2V3V4V5v 数据结构中讨论的都是简单图。数据结构中讨论的都是简单图。11/29/202210

10、Data StructureData Structure图的基本术语图的基本术语邻接、依附邻接、依附无无向向图图中中,对对于于任任意意两两个个顶顶点点vi和和顶顶点点vj,若若存存在在边边(vi,vj),则则称称顶顶点点vi和和顶顶点点vj互互为为邻邻接接点点,同同时时称称边边(vi,vj)依附于顶点依附于顶点vi和顶点和顶点vj。V1V2V3V4V5V1的邻接点:的邻接点:V2、V4V2的邻接点:的邻接点:V1、V3、V511/29/202211Data StructureData Structure图的基本术语图的基本术语邻接、依附邻接、依附有有向向图图中中,对对于于任任意意两两个个顶顶点

11、点vi和和顶顶点点vj,若若存存在在弧弧,则则称称顶顶点点vi邻邻接接到到顶顶点点vj,顶顶点点vj邻邻接接自自顶顶点点vi,同时称弧同时称弧依附于顶点依附于顶点vi和顶点和顶点vj。V1V2V3V4V1的邻接点:的邻接点:V2、V3V3的邻接点:的邻接点:V411/29/202212Data StructureData Structure无无向向完完全全图图:在在无无向向图图中中,如如果果任任意意两两个个顶顶点点之之间间都都存在边,存在边,则称该图为无向完全图。则称该图为无向完全图。有有向向完完全全图图:在在有有向向图图中中,如如果果任任意意两两个个顶顶点点之之间间都都存在方向相反的两条弧,

12、存在方向相反的两条弧,则称该图为有向完全图。则称该图为有向完全图。图的基本术语图的基本术语V1V2V3V1V2V3V411/29/202213Data StructureData Structure含有含有n个顶点的无向完全图有个顶点的无向完全图有多少多少条边?条边?含有含有n个顶点的有向完全图有个顶点的有向完全图有多少多少条弧?条弧?含有含有n个顶点的无向完全图有个顶点的无向完全图有n(n-1)/2条边。条边。含有含有n个顶点的有向完全图有个顶点的有向完全图有n(n-1)条边。条边。V1V2V3V1V2V3V411/29/202214Data StructureData Structure稀

13、疏图:稀疏图:称边数很少的图为稀疏图;称边数很少的图为稀疏图;稠密图:稠密图:称边数很多的图为稠密图。称边数很多的图为稠密图。顶顶点点的的度度:在在无无向向图图中中,顶顶点点v的的度度是是指指依依附附于于该该顶顶点的边数,通常记为点的边数,通常记为TD(v)。图的基本术语图的基本术语顶顶点点的的入入度度:在在有有向向图图中中,顶顶点点v的的入入度度是是指指以以该该顶顶点为弧头的弧的数目,点为弧头的弧的数目,记为记为ID(v);顶顶点点的的出出度度:在在有有向向图图中中,顶顶点点v的的出出度度是是指指以以该该顶顶点为弧尾的弧的数目,记为点为弧尾的弧的数目,记为OD(v)。11/29/202215

14、Data StructureData StructureV1V2V3V4V5图的基本术语图的基本术语在在具具有有n个个顶顶点点、e条条边边的的无无向向图图G中中,各各顶顶点点的度之和与边数之和的关系?的度之和与边数之和的关系?=niievTD12)(11/29/202216Data StructureData StructureV1V2V3V4图的基本术语图的基本术语在在具具有有n个个顶顶点点、e条条边边的的有有向向图图G中中,各各顶顶点点的的入入度度之之和和与与各各顶顶点点的的出出度度之之和和的的关关系系?与与边边数之和的关系?数之和的关系?evODvIDiiii=11)()(nn11/29

15、/202217Data StructureData Structure权:权:是指对边赋予的有意义的数值量。是指对边赋予的有意义的数值量。网:网:边上带权的图,也称网图。边上带权的图,也称网图。图的基本术语图的基本术语V1V2V3V4278511/29/202218Data StructureData Structure路路径径:在在无无向向图图G=(V,E)中中,从从顶顶点点vp到到顶顶点点vq之之间间的的路路径径是是一一个个顶顶点点序序列列(vp=vi0,vi1,vi2,vim=vq),其其中中,(vij-1,vij)E(1jm)。若若G是是有有向向图图,则则路路径径也也是是有方向的,顶点

16、序列满足有方向的,顶点序列满足E。图的基本术语图的基本术语V1V2V3V4V5v一般情况下,图中的路径不惟一。一般情况下,图中的路径不惟一。V1到到V4的路径:的路径:V1V4V1V2V3V4 V1V2V5V3V411/29/202219Data StructureData Structure路径长度:路径长度:图的基本术语图的基本术语非带权图非带权图路径路径上边的上边的个数个数带权图带权图路径上路径上各边的各边的权之和权之和V1V2V3V4V5V1V4:长度为:长度为1V1V2V3V4:长度为:长度为3V1V2V5V3V4:长度为:长度为411/29/202220Data Structure

17、Data Structure路径长度:路径长度:图的基本术语图的基本术语非带权图非带权图路径路径上边的上边的个数个数带权图带权图路径上路径上各边的各边的权之和权之和V1V4:长度为:长度为8V1V2V3V4:长度为:长度为7V1V2V5V3V4:长度为:长度为15V1V2V3V4V525632811/29/202221Data StructureData Structure回路(环)回路(环):第一个顶点和最后一个顶点相同的路径。:第一个顶点和最后一个顶点相同的路径。简单路径:简单路径:序列中顶点不重复出现的路径。序列中顶点不重复出现的路径。简单回路(简单环):简单回路(简单环):除了第一个顶

18、点和最后一个顶点外,其余除了第一个顶点和最后一个顶点外,其余顶点不重复出现的回路。顶点不重复出现的回路。图的基本术语图的基本术语V1V2V3V4V5V1V2V3V411/29/202222Data StructureData Structure子子图图:若若图图G=(V,E),G=(V,E),如如果果V V且且E E,则称图,则称图G是是G的子图。的子图。图的基本术语图的基本术语V1V2V3V4V5V1V2V3V4V5V1V3V411/29/202223Data StructureData Structure连连通通图图:在在无无向向图图中中,如如果果从从一一个个顶顶点点vi到到另另一一个个顶

19、顶点点vj(ij)有有路路径径,则则称称顶顶点点vi和和vj是是连连通通的的。如如果果图图中任意两个顶点都是连通的,则称该图是连通中任意两个顶点都是连通的,则称该图是连通图。图。连通分量:连通分量:非连通图的极大连通子图称为连通分量。非连通图的极大连通子图称为连通分量。图的基本术语图的基本术语如何求得一个非连通图的连通分量如何求得一个非连通图的连通分量?1.含有极大含有极大顶点顶点数;数;2.依附于这些顶点的所有依附于这些顶点的所有边边。11/29/202224Data StructureData Structure连通分量连通分量1V1V2V3V4V5V6V7V1V2V4V5V3V6V7连通

20、分量连通分量2图的基本术语图的基本术语v连通分量是对无向图的一种划分。连通分量是对无向图的一种划分。11/29/202225Data StructureData Structure强强连连通通图图:在在有有向向图图中中,对对图图中中任任意意一一对对顶顶点点vi和和vj(ij),若若从从顶顶点点vi到到顶顶点点vj和和从从顶顶点点vj到到顶顶点点vi均均有有路径,则称该有向图是强连通图。路径,则称该有向图是强连通图。强连通分量:强连通分量:非强连通图非强连通图的极大强连通子图。的极大强连通子图。图的基本术语图的基本术语如何求得一个非连通图的连通分量如何求得一个非连通图的连通分量?11/29/20

21、2226Data StructureData Structure图的基本术语图的基本术语V1V2V3V4强连通分量强连通分量1强连通分量强连通分量2V1V3V4V211/29/202227Data StructureData Structure生生成成树树:n个个顶顶点点的的连连通通图图G的的生生成成树树是是包包含含G中中全全部部顶点顶点的一个极小连通的一个极小连通子图。子图。生生成成森森林林:在在非非连连通通图图中中,由由每每个个连连通通分分量量都都可可以以得得到到一一棵棵生生成成树树,这这些些连连通通分分量量的的生生成成树树就就组组成成了了一一个个非连通图的非连通图的生成森林生成森林。如何

22、理解极小连通子图如何理解极小连通子图?图的基本术语图的基本术语多多构成回路构成回路少少不连通不连通含有含有n-1条边条边11/29/202228Data StructureData StructureV1V2V3V4V5V6V7V1V2V3V4V5V6V7V1V2V3V4V5V1V2V3V4V5生成树生成树生成森林生成森林11/29/202229Data StructureData Structureq图的抽象数据类型定义如下:图的抽象数据类型定义如下:ADT ADT GraphGraph 数据对象数据对象V V :V V是具有相同特性的数据元素的集合,称为顶是具有相同特性的数据元素的集合,称

23、为顶 点集。点集。数据关系数据关系R R :R=VRR=VRVRVR|v,wV|v,wV且且P(v,w)P(v,w),表示从表示从v v到到w w的的 弧,谓词弧,谓词P(v,w)P(v,w)定义了弧定义了弧的意义的意义 或信息或信息 11/29/202230Data StructureData StructureG1=(G1=(V1V1,VR1VR1)V1=A,B,C,D,EV1=A,B,C,D,EVR1=,VR1=,G2=(G2=(V2V2,VR2VR2)V2=A,B,C,D,E,FV2=A,B,C,D,E,FVR2=(A,B),(A,E),(B,E),(C,D),VR2=(A,B),(A

24、,E),(B,E),(C,D),(D,F),(B,F),(C,F)(D,F),(B,F),(C,F)11/29/202231Data StructureData StructureCreateGraph(&G,V,VR);CreateGraph(&G,V,VR);初始条件:初始条件:V V 是图的顶点集,是图的顶点集,VR VR 是图中弧的集合。是图中弧的集合。操作结果:按操作结果:按 V V 和和 VR VR 的定义的定义构造图构造图 G G。DestroyGraph(&G);DestroyGraph(&G);初始条件:图初始条件:图 G G 存在。存在。操作结果:操作结果:销毁图销毁图 G

25、 G。LocateVex(G,u);LocateVex(G,u);初始条件:图初始条件:图 G G 存在,存在,u u 和和 G G 中顶点有相同特征。中顶点有相同特征。操作结果:若操作结果:若 G G 中存在和中存在和 u u 相同的顶点,则相同的顶点,则返回该顶点返回该顶点 在图中位置在图中位置;否则返回其它信息。;否则返回其它信息。11/29/202232Data StructureData StructureGetVex(G,v);GetVex(G,v);初始条件:图初始条件:图 G G 存在,存在,v v 是是 G G 中某个顶点。中某个顶点。操作结果:返回操作结果:返回 v v 的

26、值的值。FirstAdjVex(G,v);FirstAdjVex(G,v);初始条件:图初始条件:图 G G 存在,存在,v v 是是 G G 中某个顶点。中某个顶点。操作结果:操作结果:返回返回 v v 的第一个邻接点。的第一个邻接点。若该顶点在若该顶点在 G G 中没中没 有邻接点,则返回有邻接点,则返回“空空”。NextAdjVex(G,v,w);NextAdjVex(G,v,w);初始条件:图初始条件:图 G G 存在,存在,v v 是是 G G 中某个顶点,中某个顶点,w w 是是 v v 的的 邻接顶点。邻接顶点。操作结果:操作结果:返回返回 v v 的(相对于的(相对于 w w

27、的)下一个邻接点。的)下一个邻接点。若若 w w 是是 v v 的最后一个邻接点,则返回的最后一个邻接点,则返回“空空”。11/29/202233Data StructureData StructurePutVex(&G,v,value);PutVex(&G,v,value);初始条件:图初始条件:图 G G 存在,存在,v v 是是 G G 中某个顶点。中某个顶点。操作结果:操作结果:对对 v v 赋值赋值 value value。InsertVex(&G,v);InsertVex(&G,v);初始条件:图初始条件:图 G G 存在,存在,v v 和图中顶点有相同特征。和图中顶点有相同特征。

28、操作结果:在图操作结果:在图 G G 中中增添新顶点增添新顶点 v v。DeleteVex(&G,v);DeleteVex(&G,v);初始条件:图初始条件:图 G G 存在,存在,v v 是是 G G 中某个顶点。中某个顶点。操作结果:操作结果:删除删除 G G 中顶点中顶点 v v 及其相关的弧及其相关的弧。11/29/202234Data StructureData StructureInsertArc(&G,v,w);InsertArc(&G,v,w);初始条件:图初始条件:图 G G 存在,存在,v v 和和 w w 是是 G G 中两个顶点。中两个顶点。操作结果:在操作结果:在 G

29、 G 中中增添弧增添弧,若,若 G G 是是无向的,则还无向的,则还 增添对称弧增添对称弧。DeleteArc(&G,v,w);DeleteArc(&G,v,w);初始条件:图初始条件:图 G G 存在,存在,v v 和和 w w 是是 G G 中两个顶点。中两个顶点。操作结果:在操作结果:在 G G 中中删除弧删除弧,若若 G G 是是无向的,则还无向的,则还 删除对称弧删除对称弧。11/29/202235Data StructureData StructureDFSTraverse(G,Visit();DFSTraverse(G,Visit();初始条件:图初始条件:图 G G 存在,存在

30、,Visit Visit 是顶点的应用函数。是顶点的应用函数。操作结果:对图操作结果:对图 G G 进行进行深度优先深度优先遍历。遍历过程中对每遍历。遍历过程中对每 个顶点调用函数个顶点调用函数Visit Visit 一次且仅一次。一旦一次且仅一次。一旦 visit()visit()失败,则操作失败。失败,则操作失败。FSTraverse(G,Visit();FSTraverse(G,Visit();初始条件:图初始条件:图 G G 存在,存在,Visit Visit 是顶点的应用函数。是顶点的应用函数。操作结果:对图操作结果:对图 G G 进行进行广度优先广度优先遍历。遍历过程中对每遍历。遍

31、历过程中对每 个顶点调用函数个顶点调用函数Visit Visit 一次且仅一次。一旦一次且仅一次。一旦 visit()visit()失败,则操作失败。失败,则操作失败。ADT Graph ADT Graph11/29/202236Data StructureData Structure是否可以采用顺序存储结构存储图是否可以采用顺序存储结构存储图?图的特点:顶点之间的关系是图的特点:顶点之间的关系是m:n,即,即任何两任何两个顶点之间都可能存在关系(边),无法通过个顶点之间都可能存在关系(边),无法通过存储位置表示这种任意的逻辑关系,所以,图存储位置表示这种任意的逻辑关系,所以,图无法采用顺序存

32、储结构。无法采用顺序存储结构。如何存储图如何存储图?考虑图的定义,图是由顶点和边组成的,分别考虑图的定义,图是由顶点和边组成的,分别考虑如何存储顶点、如何存储边。考虑如何存储顶点、如何存储边。7.2 7.2 图的存储结构图的存储结构图的存储结构图的存储结构11/29/202237Data StructureData Structure7.2 7.2 7.2 7.2 图的存储结构图的存储结构图的存储结构图的存储结构q数组表示法数组表示法(邻接矩阵邻接矩阵)v将图的将图的顶点信息存储在一个一维数组中顶点信息存储在一个一维数组中,并将它的,并将它的邻接矩阵存邻接矩阵存储在一个二维数组中储在一个二维数

33、组中即构成图的数组表示。即构成图的数组表示。v假设图中顶点数为假设图中顶点数为n n,则邻接矩阵,则邻接矩阵A A定义为定义为网的邻接矩阵的定义为,当网的邻接矩阵的定义为,当v vi i到到v vj j有弧相邻接时,有弧相邻接时,a aijij的值应为该的值应为该弧上的权值,否则为弧上的权值,否则为。11/29/202238Data StructureData Structurev图的数组图的数组(邻接矩阵邻接矩阵)存储表示存储表示#define INFINITY#define INFINITY INT_MAX;INT_MAX;/最大值最大值#define MAX_VERTEX_NUM#def

34、ine MAX_VERTEX_NUM 20;20;/最大顶点个数最大顶点个数typedef enum DG,DN,UDG,UDN GraphKind;typedef enum DG,DN,UDG,UDN GraphKind;/有向图有向图,有向网有向网,无向图无向图,无向网无向网 typedef struct ArcCell typedef struct ArcCell VRType VRType adj;adj;/VRType/VRType是顶点关系类型。对无权图,用是顶点关系类型。对无权图,用1 1或或0 0 /表示相邻否;对带权图,则为权值类型。表示相邻否;对带权图,则为权值类型。Inf

35、oType InfoType*info;*info;/该弧相关信息的指针该弧相关信息的指针 ArcCell,ArcCell,AdjMatrixMAX_VERTEX_NUMMAX_VERTEX_NUMAdjMatrixMAX_VERTEX_NUMMAX_VERTEX_NUM;typedef struct typedef struct VertexType VertexType vexsMAX_VERTEX_NUMvexsMAX_VERTEX_NUM;/顶点信息顶点信息AdjMatrix AdjMatrix arcsarcs;/邻接矩阵邻接矩阵int int vexnum,arcnumvexnum

36、,arcnum;/图的当前顶点数和弧图的当前顶点数和弧(边边)数数GraphKind GraphKind kindkind;/图的种类标志图的种类标志 MGraphMGraph;11/29/202239Data StructureData Structure有向图的存储结构有向图的存储结构G1G1BDACG1.vexs=A,B,C,DG1.vexnum=4G1.arcnum=4G1.kind=DG11/29/202240Data StructureData Structure有向图的邻接矩阵有向图的邻接矩阵V1V2V3V4V1V2V3V4vertex=0110000000011000arc=V

37、1V2V3V4V1V2V3V4如何求顶点如何求顶点i 的出度?的出度?邻接矩阵的第邻接矩阵的第i 行元素之和。行元素之和。11/29/202241Data StructureData Structure有向图的邻接矩阵有向图的邻接矩阵V1V2V3V4V1V2V3V4vertex=0110000000011000arc=V1V2V3V4V1V2V3V4如何求顶点如何求顶点i 的入度?的入度?邻接矩阵的第邻接矩阵的第i 列元素之和。列元素之和。11/29/202242Data StructureData Structure有向图的邻接矩阵有向图的邻接矩阵V1V2V3V4V1V2V3V4vertex

38、=0110000000011000arc=V1V2V3V4V1V2V3V4如何判断从顶点如何判断从顶点i 到顶点到顶点j 是否存在边?是否存在边?测试邻接矩阵中相应位置的元素测试邻接矩阵中相应位置的元素arcij是否为是否为1。11/29/202243Data StructureData Structure无向图的存储结构无向图的存储结构AECBDG2G2G2.vexs=A,B,C,D,EG2.vexnum=5G2.arcnum=6G2.kind=UDG11/29/202244Data StructureData Structure网图的存储结构网图的存储结构A AD DE EB BC C7

39、75 53 31 18 86 64 42 2G3G3G3.vexs=A,B,C,D,EG3.vexnum=5G3.arcnum=8G3.kind=UDN11/29/202245Data StructureData Structure如何求顶点如何求顶点i的度?的度?无向图的邻接矩阵无向图的邻接矩阵V1V3V4V2V1V2V3V4vertex=0101101101001100arc=V1V2V3V4V1V2V3V4邻接矩阵的第邻接矩阵的第i行(或第行(或第i列)非零元素的个数。列)非零元素的个数。11/29/202246Data StructureData Structure如何判断顶点如何判断

40、顶点i 和和j 之间是否存在边?之间是否存在边?无向图的邻接矩阵无向图的邻接矩阵V1V3V4V2V1V2V3V4vertex=0101101101001100arc=V1V2V3V4V1V2V3V4测试邻接矩阵中相应位置的元素测试邻接矩阵中相应位置的元素arcij是否为是否为1。11/29/202247Data StructureData Structure如何求顶点如何求顶点i 的所有邻接点?的所有邻接点?无向图的邻接矩阵无向图的邻接矩阵V1V3V4V2V1V2V3V4vertex=0101101101001100arc=V1V2V3V4V1V2V3V4将数组中第将数组中第i行元素扫描一遍,

41、若行元素扫描一遍,若arcij为为1,则,则顶点顶点j为顶点为顶点i 的邻接点。的邻接点。11/29/202248Data StructureData Structurev特点特点:无向图无向图的邻接的邻接矩阵对称矩阵对称,可,可压缩存储压缩存储;有;有n n个顶点的无向图需个顶点的无向图需存储空间为存储空间为n(n+1)/2n(n+1)/2。有向图有向图邻接邻接矩阵不一定对称矩阵不一定对称;有;有n n个顶点的有向图需存储空间个顶点的有向图需存储空间为为n n。无向图无向图中顶点中顶点ViVi的度的度TD(Vi)TD(Vi)是邻接矩阵是邻接矩阵A A中第中第i i行元素之和行元素之和。有向图

42、有向图中,中,顶点顶点ViVi的的出度是出度是A A中第中第i i行元素之和行元素之和。顶点顶点ViVi的的入度是入度是A A中第中第i i列元素之和列元素之和。v邻接矩阵的优缺点邻接矩阵的优缺点优点优点:容易判定顶点间有无边(弧)和计算顶点的度(出度、:容易判定顶点间有无边(弧)和计算顶点的度(出度、入度)。入度)。缺点缺点:边数较少时,空间浪费较大。:边数较少时,空间浪费较大。11/29/202249Data StructureData Structure网图的邻接矩阵网图的邻接矩阵网图的邻接矩阵可定义为:网图的邻接矩阵可定义为:arcijwij若若(vi,vj)E(或(或E)0若若i=j

43、其他其他V1V2V3V4278502500870arc=11/29/202250Data StructureData Structure7.2.2 7.2.2 7.2.2 7.2.2 图的邻接表表示法图的邻接表表示法图的邻接表表示法图的邻接表表示法q引入原因引入原因v邻接矩阵在稀疏图时空间浪费较大。邻接矩阵在稀疏图时空间浪费较大。q实现实现v为图中为图中每个顶点建立一个单链表每个顶点建立一个单链表,第,第i i个单链表中的结点表示依附个单链表中的结点表示依附于顶点于顶点ViVi的边(有向图中指以的边(有向图中指以ViVi为尾的弧)。为尾的弧)。v每个链表附设一个表头结点每个链表附设一个表头结点

44、。表结点表结点adjvexadjvexnextarcnextarcinfoinfo与与ViVi邻接的邻接的点在表头数点在表头数组中的位置组中的位置头结点头结点datadatafirstarcfirstarc11/29/202251Data StructureData Structure图的邻接表存储表示图的邻接表存储表示#define MAX_VERTEX_NUM 20;#define MAX_VERTEX_NUM 20;typedef struct ArcNode typedef struct ArcNode int int adjvex;adjvex;/该弧所指向的顶点的位置该弧所指向的顶

45、点的位置struct ArcNode struct ArcNode*nextarc;*nextarc;/指向下一条弧的指针指向下一条弧的指针InfoType InfoType*info;*info;/该弧相关信息的指针该弧相关信息的指针 ArcNode;ArcNode;typedef struct VNode typedef struct VNode VertexType VertexType data;data;/顶点信息顶点信息ArcNode ArcNode*firstarc;*firstarc;/指向第一条依附该顶点的弧指向第一条依附该顶点的弧 AdjListMAX_VERTEX_NUM

46、AdjListMAX_VERTEX_NUM;typedef struct typedef struct AdjList AdjList verticesvertices;/顶点数组顶点数组int vexnum,arcnum;int vexnum,arcnum;/图的当前顶点数和弧数图的当前顶点数和弧数int kind;int kind;/图的种类标志图的种类标志 ALGraphALGraph;11/29/202252Data StructureData Structure10323101V1V2V3V40123vertexfirstedgeV1V3V4V2无向图的邻接表无向图的邻接表边表中的结

47、点表示什么?边表中的结点表示什么?每个结点对应图中的一条边,每个结点对应图中的一条边,邻接表的空间复杂度为邻接表的空间复杂度为O(n+e)。11/29/202253Data StructureData Structure10323101V1V2V3V40123vertexfirstedgeV1V3V4V2无向图的邻接表无向图的邻接表如何求顶点如何求顶点i 的度?的度?顶点顶点i的边表中结点的个数。的边表中结点的个数。11/29/202254Data StructureData Structure如何判断顶点如何判断顶点i 和顶点和顶点j之间是否存在边之间是否存在边?测试顶点测试顶点i 的边表中

48、是否存的边表中是否存在终点为在终点为j 的结点。的结点。10323101V1V2V3V40123vertexfirstedgeV1V3V4V2无向图的邻接表无向图的邻接表11/29/202255Data StructureData Structure有向图的邻接表有向图的邻接表V1V2V3V41220V1V2V3V40123vertexfirstedge如何求顶点如何求顶点i 的出度?的出度?顶点顶点i 的出边表中结点的个数。的出边表中结点的个数。11/29/202256Data StructureData Structure有向图的邻接表有向图的邻接表V1V2V3V41220V1V2V3V4

49、0123vertexfirstedge如何求顶点如何求顶点i 的入度?的入度?各顶点的出边表中以顶点各顶点的出边表中以顶点i 为为终点的结点个数。终点的结点个数。11/29/202257Data StructureData Structure有向图的邻接表有向图的邻接表V1V2V3V41230V1V2V3V40123vertexfirstedge如何求顶点如何求顶点i 的所有邻接点?的所有邻接点?遍历顶点遍历顶点i 的边表,该边表中的的边表,该边表中的所有终点都是顶点所有终点都是顶点i 的邻接点。的邻接点。11/29/202258Data StructureData Structure网图的邻

50、接表网图的邻接表V1V2V3V4278521V1V2V3V40123vertexfirstedge52837011/29/202259Data StructureData Structurev优缺点优缺点优点优点:空间较省;无向图容易求各顶点的度;有向图容易:空间较省;无向图容易求各顶点的度;有向图容易求顶点的出度;求顶点的出度;缺点缺点:求有向图顶点的入度则不容易,要遍历整个表。:求有向图顶点的入度则不容易,要遍历整个表。为了求顶点的入度,有时可设逆邻接表(指向某顶点的邻为了求顶点的入度,有时可设逆邻接表(指向某顶点的邻接点链接成单链表)。接点链接成单链表)。bdac0123acdbdata

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 大学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com