数据结构图论部分.ppt
《数据结构图论部分.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 的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据 结构图 部分
限制150内