图的遍历课件_第1页
图的遍历课件_第2页
图的遍历课件_第3页
图的遍历课件_第4页
图的遍历课件_第5页
已阅读5页,还剩87页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1EssentialofLectureFifteen

一、图的遍历(深度、广度)二、最小生成树三、普里姆算法四、克鲁斯卡尔算法第十五讲图的遍历难点1EssentialofLectureFiftee2

图的遍历:从图的某顶点出发,访问图中所有顶点,并且每个顶点仅访问一次。 在图中,访问部分顶点后,可能又沿着其他边回到已被访问过的顶点。 为保证每一个顶点只被访问一次,必须对顶点进行标记,一般用一个标识域tag作为对顶点的标记,当顶点vi未被访问,tag初始值为UNVISITED;当vi已被访问,则tag值为VISITED。

一、图的遍历TraversingGraph2 图的遍历:从图的某顶点出发,访问图中所有顶点,并且每个顶3图的遍历与树的遍历有什么不同?

有两种遍历方法(它们对无向图,有向图都适用)深度优先遍历Depth_FirstSearch

广度优先遍历Breadth_FirstSearch一、图的遍历3图的遍历与?有两种遍历方法(它们对无向图,有向图都适4一、图的遍历算法:从图中某顶点v出发:(1)访问顶点v;

(2)依次从v的未被访问的邻接点出发,继续对图进行深度优先遍历;1、深度优先遍历4一、图的遍历算法:1、深度优先遍历5深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5

V5一、图的遍历5深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V6深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5V8

V8一、图的遍历6深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V7深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5V8一、图的遍历7深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V8深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1

V7V2V4V5V8V3

V3V6

V6V7一、图的遍历8深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V9template<classElemType>voidDFSTraverse(constAdjMatrixDirGraph<ElemType>&g,void(*Visit)(constElemType&)){ intv; for(v=0;v<g.GetVexNum();v++) { g.SetTag(v,UNVISITED); } for(v=0;v<g.GetVexNum();v++) { if(g.GetTag(v)==UNVISITED) DFS<ElemType>(g,v,Visit); }}图的深度优先遍历算法9template<classElemType>图的深度10template<classElemType>voidDFS(constAdjMatrixDirGraph<ElemType>&g,intv,void(*Visit)(constElemType&)){ g.SetTag(v,VISITED); ElemTypee=g.GetVexData(v); Visit(e); for(intw=g.FirstAdjVex(v);w!=-1; w=g.NextAdjVex(v,w)) {if(g.GetTag(w)==UNVISITED) { DFS<ElemType>(g,w,Visit); } }}图的深度优先遍历算法10template<classElemType>图的深11一、图的遍历

A

H

G

F

E

D

C

B图的深度优先遍历算法

01234567ABCDEFGH12673011045362523411一、图的遍历AHGFEDCB图的深度优先12算法分析图中有n个顶点,e条边。如果用邻接表表示图,沿adjLink链到next链可以找到某个顶点v的所有邻接顶点w。由于总共有2e个边结点,所以扫描边的时间为O(e)。而且对所有顶点递归访问1次,所以遍历图的时间复杂性为O(n+e)。如果用邻接矩阵表示图,则查找每一个顶点的所有的边,所需时间为O(n),则遍历图中所有的顶点所需的时间为O(n2)。12算法分析图中有n个顶点,e条边。13考研题分析有向图的邻接表如下,要求(1)画出其邻接矩阵存储;(2)写出图的所有强连同分量;(3)写出顶点a到顶点i的全部简单路径;(4)写出以A为出发点开始深度优先遍历得到的顶点序列。

123456789ABEDHICGF27634528739613考研题分析有向图的邻接表如下,要求(1)画出其邻接矩阵存14考研题分析已知一个有向图如下,则从顶点a出发进行深度优先遍历,不可能够得到的DFS序列为?AadbefcBadcefbCadcbfeDadefbcacefdb14考研题分析已知一个有向图如下,则从顶点a出发进行深度优先15一、图的遍历算法:从图中某未访问过的顶点vi出发:(1)访问顶点vi;(2)访问vi的所有未被访问的邻接点w1,w2,…wk

;(3)依次从这些邻接点出发,访问它们的所有未被访问的邻接点;依此类推,直到图中所有访问过的顶点的邻接点都被访问;2、广度优先遍历(类似于树的层次遍历)15一、图的遍历算法:2、广度优先遍历(类似于树的层次遍历)16为实现(3),需要保存在步骤(2)中访问的顶点,而且访问这些顶点邻接点的顺序为:先保存的顶点,其邻接点先被访问。一、图的遍历2、广度优先遍历在广度优先遍历算法中,需设置一队列Q,保存已访问的顶点,并控制遍历顶点的顺序。

V1

V8

V7

V6

V5

V4

V3

V216为实现(3),需要保存在步骤(2)中访问的顶点,而且访问17广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V1一、图的遍历17广度优先遍历序列?入队序列?出队序列?V1V3V18广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V2V3V3一、图的遍历18广度优先遍历序列?入队序列?出队序列?V1V3V19广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V3V4V4V5V5一、图的遍历19广度优先遍历序列?入队序列?出队序列?V1V3V20广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V4V4V5V5V6V6V7V7一、图的遍历20广度优先遍历序列?入队序列?出队序列?V1V3V21广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V4V5V5V6V6V7V7V8V8一、图的遍历21广度优先遍历序列?入队序列?出队序列?V1V3V22template<classElemType>voidBFSTraverse(constAdjListDirGraph<ElemType>&g,void(*Visit)(constElemType&)){ intv; for(v=0;v<g.GetVexNum();v++) { g.SetTag(v,UNVISITED); } for(v=0;v<g.GetVexNum();v++) { if(g.GetTag(v)==UNVISITED) { BFS<ElemType>(g,v,Visit); } }}图的广度优先遍历算法22template<classElemType>图的广23template<classElemType>voidBFS(constAdjListDirGraph<ElemType>&g,intv,void(*Visit)(constElemType&)){ g.SetTag(v,VISITED); ElemTypee; g.GetElem(v,e); Visit(e); LinkQueue<int>q; q.InQueue(v);

图的广度优先遍历算法23template<classElemType>图的广24 while(!q.Empty()) { //队列q非空,进行循环 intu,w; q.OutQueue(u); for(w=g.FirstAdjVex(v);w>=0;w=g.NextAdjVex(v,w)) { if(g.GetTag(w)==UNVISITED) { g.SetTag(w,VISITED); g.GetElem(w,e); Visit(e); q.InQueue(w); } }}}图的广度优先遍历算法24 while(!q.Empty())图的广度优先遍历算25

V0

V2

V3

V1

V5

V4

V0

V2

V3

V1

V5

V4深度优先遍历广度优先遍历两种遍历的比较一、图的遍历两者遍历的时间复杂度相同,不同之处仅仅在于对顶点访问的顺序。25V0V2V3V1V5V4V0V2V326二、图的连通性问题无向图的连通分量和生成树

生成树是一个连通图G的一个极小的连通子图。包含图G的所有顶点,但只有n-1条边,并且是连通的。生成树可由遍历过程中所经过的边组成。深度优先遍历得到的生成树称为深度优先生成树;广度优先遍历得到的生成树称为广度优先生成树。生成森林:非连通图每个连通分量的生成树一起组成非连通图的生成森林。26二、图的连通性问题无向图的连通分量和生成树27V1V2V4V5V3V7V6V8例深度遍历:V1V2V4V8V5V3V6V7V1V2V4V5V3V7V6V8深度优先生成树V1V2V4V5V3V7V6V8广度优先生成树V1V2V4V5V3V7V6V8V1V2V4V5V3V7V6V8广度遍历:V1V2V3V4V5V6V7V827V1V2V4V5V3V7V6V8例深度遍历:V1V228ABLMCFDEGHKIJABLMCFJDEGHKI深度优先生成森林例28ABLMCFDEGHKIJABLMCFJDEGHKI深度29二、图的连通性问题说明一个图可以有许多棵不同的生成树所有生成树具有以下共同特点:生成树的顶点个数与图的顶点个数相同生成树是图的极小连通子图一个有n个顶点的连通图的生成树有n-1条边生成树中任意两个顶点间的路径是唯一的在生成树中再加一条边必然形成回路

含n个顶点n-1条边的图不一定是生成树1、生成树和生成森林GHKI29二、图的连通性问题说明1、生成树和生成森林GHKI30

要在n个城市间建立交通网,要考虑的问题如何在保证n点连通的前题下最节省经费?V2V0V3V5V4

求解:连通6个城市且代价最小的交通线路?如何求连通图的最小生成树??

若有一个连通的无向图G,有n个顶点,并且它的边是有权值的。在G上构造生成树G’,最小生成树是n-1条边的权值之和最小的G’

。二、图的连通性问题30

要在n个城市间建立交通网,要考虑的问题如31①普里姆算法Prim②克鲁斯卡尔算法Kruskal二、图的连通性问题2、最小代价生成树MinimumCostSpanningTree31①普里姆算法Prim二、图的连通性问题2、最小代价生32例1654328613688526131163151643152116432152616543215263①普里姆算法Prim32例16543286136885261311631516433

普里姆算法基本步骤设N=(V,E)为一个具有n个顶点的带权的连通网络,T=(U,TE)为构造的生成树。

(1)初始时,U={U0},TE={};

(2)在所有uU、vV-U的边(u,v)E中选择一条权值最小的边(u0,v0);

(3)(u0,v0)加入集合TE,同时将v0加入U;

(4)重复(2)、(3),直到U=V为止;二、图的连通性问题33普里姆算法基本步骤二、图的连通性问题34abcdegf195141827168213ae12dcbgf7148531621所得生成树权值和=14+8+3+5+16+21=67再如:34abcdegf195141827168213ae12dc35

克鲁斯卡尔算法二、图的连通性问题Kruskal的基本思想:设有一个有n个顶点的连通网络N={V,E},最初先构造一个只有n个顶点,没有边的非连通图T={V,},图中每个顶点自成一个连通分量。在E中选到一条具有最小权值的边,若该边的两个顶点落在不同的连通分量上,则将此边加入到T中;否则将此边舍去,重新选择一条权值最小的边。如此重复下去,直到所有顶点在同一个连通分量上为止。35克鲁斯卡尔算法二、图的连通性问题Kruskal的基本36应用克鲁斯卡尔算法构造最小生成树的过程5046132281025142422161812原图二、图的连通性问题

克鲁斯卡尔算法5046132(a)105046132(b)36应用克鲁斯卡尔算法构造最小生成树的过程50461322837504612281025142422161812原图3(f)50461321014221612504613210141612(e)5046121025142216123(g)10125046132(c)5046132101412(d)37504612281025142422161812原图3(381.初始化:U=V;TE={};2.循环直到T中的连通分量个数为12.1在E中寻找最短边(u,v);2.2如果顶点u、v位于T的两个不同连通分量,则

2.2.1将边(u,v)并入TE;

2.2.2将这两个连通分量合为一个;

2.3在E中标记边(u,v),使得(u,v)不参加后续最短边的选取;Kruskal算法——伪代码二、图的连通性问题381.初始化:U=V;TE={};Kruskal39Prim与Kruskal算法的性能比较:

(1)时间复杂性:Prim:O(n*n)Kruskal:O(eloge)(2)适用场合:Prim:稠密图

Kruskal:稀疏图

二、图的连通性问题39Prim与Kruskal算法的性能比较:二、图的连通性问40【ACM】【ZOJ1406】最小生成树问题【问题描述】40【ACM】【ZOJ1406】最小生成树问题【问题描述】41如上图所示,给出结点数量N,以及每个结点到相邻结点的距离,要求给出一条最短连通路径,连通所有结点(结点的字母不重复,个数不超过26个)。根据上图我们可以给出如下一组数据:

9A2B12I25B3C10H40I8C2D18G55D1E44E2F60G38F0G1H35H1I35第一行的9表示有9个结点,接下来共8行数据,每行数据给出该结点的名称name,和相邻结点数num,以及与相邻结点X之间的距离Y。41如上图所示,给出结点数量N,以及每个结点到相邻结点的距离42

不难发现,每行结点只给出了结点名称大于该结点的相邻结点的距离。比如B与A相邻,且距离为12。在第一行A“结点信息表”中给出了A到B的距离12,但在第二行B“结点信息表”中就不必给出小于字母B的A结点的信息(为了避免数据冗余)。所以最后一个结点I,没有比它字母再大的结点,故省略该行。

要求最后得出一条最短连通路径,把该路径长度输出,在本例中路径长度为216(如右图所示)。下面现场用克鲁斯卡尔算法实现42不难发现,每行结点只给出了结点名称大于该结点的相邻结43【ACM】【POJ2168】有向图的强连通分量题意:有一群牛,总数为N(N<=10000),题目数据给出牛之间的关系,比如1仰慕2,2仰慕3等等,设这种仰慕是可以传递的,如果1仰慕2,那么1也会同时仰慕2仰慕的那些牛,如果一头牛被所有的牛都仰慕,那么它将是最受欢迎的牛,题目要求的是有多少牛是"最受欢迎的"。43【ACM】【POJ2168】题意:有一群牛,总数为N(44在同一个强连通分量里的所有的牛之间是互相仰慕的,我们将其缩为一点,并且只记录这一点的牛的数量,如果有最受欢迎的牛存在,那么这个图将是连通图,并且出度为零的点只有一个,我们需要判断是否连通,然后计算每个节点的出度,即可求出最受欢迎的牛的数量。请有兴趣的同学试着写一写。44在同一个强连通分量里的所有的牛之间是互相仰慕的,我们将其45本讲小结重点:

1、图的深度、广度遍历

2、克鲁斯卡尔算法难点:

1、普里姆算法45本讲小结重点:46对下面的连通图,分别用Prim和Kruskal算法构造其最小生成树,后者给出图解过程。1238765422221111243seeyoulater!46对下面的连通图,分别用Prim和Kruskal算法构造其47EssentialofLectureFifteen

一、图的遍历(深度、广度)二、最小生成树三、普里姆算法四、克鲁斯卡尔算法第十五讲图的遍历难点1EssentialofLectureFiftee48

图的遍历:从图的某顶点出发,访问图中所有顶点,并且每个顶点仅访问一次。 在图中,访问部分顶点后,可能又沿着其他边回到已被访问过的顶点。 为保证每一个顶点只被访问一次,必须对顶点进行标记,一般用一个标识域tag作为对顶点的标记,当顶点vi未被访问,tag初始值为UNVISITED;当vi已被访问,则tag值为VISITED。

一、图的遍历TraversingGraph2 图的遍历:从图的某顶点出发,访问图中所有顶点,并且每个顶49图的遍历与树的遍历有什么不同?

有两种遍历方法(它们对无向图,有向图都适用)深度优先遍历Depth_FirstSearch

广度优先遍历Breadth_FirstSearch一、图的遍历3图的遍历与?有两种遍历方法(它们对无向图,有向图都适50一、图的遍历算法:从图中某顶点v出发:(1)访问顶点v;

(2)依次从v的未被访问的邻接点出发,继续对图进行深度优先遍历;1、深度优先遍历4一、图的遍历算法:1、深度优先遍历51深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5

V5一、图的遍历5深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V52深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5V8

V8一、图的遍历6深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V53深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1V2

V2V4

V4V5V8一、图的遍历7深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V54深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V1V3V2V4V5V6V7V8

V1遍历序列:V1

V7V2V4V5V8V3

V3V6

V6V7一、图的遍历8深一层递归递归返回深度优先遍历序列?入栈序列?出栈序列?V55template<classElemType>voidDFSTraverse(constAdjMatrixDirGraph<ElemType>&g,void(*Visit)(constElemType&)){ intv; for(v=0;v<g.GetVexNum();v++) { g.SetTag(v,UNVISITED); } for(v=0;v<g.GetVexNum();v++) { if(g.GetTag(v)==UNVISITED) DFS<ElemType>(g,v,Visit); }}图的深度优先遍历算法9template<classElemType>图的深度56template<classElemType>voidDFS(constAdjMatrixDirGraph<ElemType>&g,intv,void(*Visit)(constElemType&)){ g.SetTag(v,VISITED); ElemTypee=g.GetVexData(v); Visit(e); for(intw=g.FirstAdjVex(v);w!=-1; w=g.NextAdjVex(v,w)) {if(g.GetTag(w)==UNVISITED) { DFS<ElemType>(g,w,Visit); } }}图的深度优先遍历算法10template<classElemType>图的深57一、图的遍历

A

H

G

F

E

D

C

B图的深度优先遍历算法

01234567ABCDEFGH12673011045362523411一、图的遍历AHGFEDCB图的深度优先58算法分析图中有n个顶点,e条边。如果用邻接表表示图,沿adjLink链到next链可以找到某个顶点v的所有邻接顶点w。由于总共有2e个边结点,所以扫描边的时间为O(e)。而且对所有顶点递归访问1次,所以遍历图的时间复杂性为O(n+e)。如果用邻接矩阵表示图,则查找每一个顶点的所有的边,所需时间为O(n),则遍历图中所有的顶点所需的时间为O(n2)。12算法分析图中有n个顶点,e条边。59考研题分析有向图的邻接表如下,要求(1)画出其邻接矩阵存储;(2)写出图的所有强连同分量;(3)写出顶点a到顶点i的全部简单路径;(4)写出以A为出发点开始深度优先遍历得到的顶点序列。

123456789ABEDHICGF27634528739613考研题分析有向图的邻接表如下,要求(1)画出其邻接矩阵存60考研题分析已知一个有向图如下,则从顶点a出发进行深度优先遍历,不可能够得到的DFS序列为?AadbefcBadcefbCadcbfeDadefbcacefdb14考研题分析已知一个有向图如下,则从顶点a出发进行深度优先61一、图的遍历算法:从图中某未访问过的顶点vi出发:(1)访问顶点vi;(2)访问vi的所有未被访问的邻接点w1,w2,…wk

;(3)依次从这些邻接点出发,访问它们的所有未被访问的邻接点;依此类推,直到图中所有访问过的顶点的邻接点都被访问;2、广度优先遍历(类似于树的层次遍历)15一、图的遍历算法:2、广度优先遍历(类似于树的层次遍历)62为实现(3),需要保存在步骤(2)中访问的顶点,而且访问这些顶点邻接点的顺序为:先保存的顶点,其邻接点先被访问。一、图的遍历2、广度优先遍历在广度优先遍历算法中,需设置一队列Q,保存已访问的顶点,并控制遍历顶点的顺序。

V1

V8

V7

V6

V5

V4

V3

V216为实现(3),需要保存在步骤(2)中访问的顶点,而且访问63广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V1一、图的遍历17广度优先遍历序列?入队序列?出队序列?V1V3V64广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V2V3V3一、图的遍历18广度优先遍历序列?入队序列?出队序列?V1V3V65广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V3V4V4V5V5一、图的遍历19广度优先遍历序列?入队序列?出队序列?V1V3V66广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V4V4V5V5V6V6V7V7一、图的遍历20广度优先遍历序列?入队序列?出队序列?V1V3V67广度优先遍历序列?入队序列?出队序列?V1V3V2V4V5V6V7V8遍历序列:V1V2V3V4V5V5V6V6V7V7V8V8一、图的遍历21广度优先遍历序列?入队序列?出队序列?V1V3V68template<classElemType>voidBFSTraverse(constAdjListDirGraph<ElemType>&g,void(*Visit)(constElemType&)){ intv; for(v=0;v<g.GetVexNum();v++) { g.SetTag(v,UNVISITED); } for(v=0;v<g.GetVexNum();v++) { if(g.GetTag(v)==UNVISITED) { BFS<ElemType>(g,v,Visit); } }}图的广度优先遍历算法22template<classElemType>图的广69template<classElemType>voidBFS(constAdjListDirGraph<ElemType>&g,intv,void(*Visit)(constElemType&)){ g.SetTag(v,VISITED); ElemTypee; g.GetElem(v,e); Visit(e); LinkQueue<int>q; q.InQueue(v);

图的广度优先遍历算法23template<classElemType>图的广70 while(!q.Empty()) { //队列q非空,进行循环 intu,w; q.OutQueue(u); for(w=g.FirstAdjVex(v);w>=0;w=g.NextAdjVex(v,w)) { if(g.GetTag(w)==UNVISITED) { g.SetTag(w,VISITED); g.GetElem(w,e); Visit(e); q.InQueue(w); } }}}图的广度优先遍历算法24 while(!q.Empty())图的广度优先遍历算71

V0

V2

V3

V1

V5

V4

V0

V2

V3

V1

V5

V4深度优先遍历广度优先遍历两种遍历的比较一、图的遍历两者遍历的时间复杂度相同,不同之处仅仅在于对顶点访问的顺序。25V0V2V3V1V5V4V0V2V372二、图的连通性问题无向图的连通分量和生成树

生成树是一个连通图G的一个极小的连通子图。包含图G的所有顶点,但只有n-1条边,并且是连通的。生成树可由遍历过程中所经过的边组成。深度优先遍历得到的生成树称为深度优先生成树;广度优先遍历得到的生成树称为广度优先生成树。生成森林:非连通图每个连通分量的生成树一起组成非连通图的生成森林。26二、图的连通性问题无向图的连通分量和生成树73V1V2V4V5V3V7V6V8例深度遍历:V1V2V4V8V5V3V6V7V1V2V4V5V3V7V6V8深度优先生成树V1V2V4V5V3V7V6V8广度优先生成树V1V2V4V5V3V7V6V8V1V2V4V5V3V7V6V8广度遍历:V1V2V3V4V5V6V7V827V1V2V4V5V3V7V6V8例深度遍历:V1V274ABLMCFDEGHKIJABLMCFJDEGHKI深度优先生成森林例28ABLMCFDEGHKIJABLMCFJDEGHKI深度75二、图的连通性问题说明一个图可以有许多棵不同的生成树所有生成树具有以下共同特点:生成树的顶点个数与图的顶点个数相同生成树是图的极小连通子图一个有n个顶点的连通图的生成树有n-1条边生成树中任意两个顶点间的路径是唯一的在生成树中再加一条边必然形成回路

含n个顶点n-1条边的图不一定是生成树1、生成树和生成森林GHKI29二、图的连通性问题说明1、生成树和生成森林GHKI76

要在n个城市间建立交通网,要考虑的问题如何在保证n点连通的前题下最节省经费?V2V0V3V5V4

求解:连通6个城市且代价最小的交通线路?如何求连通图的最小生成树??

若有一个连通的无向图G,有n个顶点,并且它的边是有权值的。在G上构造生成树G’,最小生成树是n-1条边的权值之和最小的G’

。二、图的连通性问题30

要在n个城市间建立交通网,要考虑的问题如77①普里姆算法Prim②克鲁斯卡尔算法Kruskal二、图的连通性问题2、最小代价生成树MinimumCostSpanningTree31①普里姆算法Prim二、图的连通性问题2、最小代价生78例1654328613688526131163151643152116432152616543215263①普里姆算法Prim32例16543286136885261311631516479

普里姆算法基本步骤设N=(V,E)为一个具有n个顶点的带权的连通网络,T=(U,TE)为构造的生成树。

(1)初始时,U={U0},TE={};

(2)在所有uU、vV-U的边(u,v)E中选择一条权值最小的边(u0,v0);

(3)(u0,v0)加入集合TE,同时将v0加入U;

(4)重复(2)、(3),直到U=V为止;二、图的连通性问题33普里姆算法基本步骤二、图的连通性问题80abcdegf195141827168213ae12dcbgf7148531621所得生成树权值和=14+8+3+5+16+21=67再如:34abcdegf195141827168213ae12dc81

克鲁斯卡尔算法二、图的连通性问题Kruskal的基本思想:设有一个有n个顶点的连通网络N={V,E},最初先构造一个只有n个顶点,没有边的非连通图T={V,},图中每个顶点自成一个连通分量。在E中选到一条具有最小权值的边,若该边的两个顶点落在不同的连通分量上,则将此边加入到T中;否则将此边舍去,重新选择一条权值最小的边。如此重复下去,直到所有顶点在同一个连通分量上为止。35克鲁斯卡尔算法二、图的连通性问题Kruskal的基本82应用克鲁斯卡尔算法构造最小生成树的过程5046132281025142422161812原图二、图的连通性问题

克鲁斯卡尔算法5046132(a)105046132(b)36应用克鲁斯卡尔算法构造最小生成树的过程50461322883504612281025142422161812原图3(f)50461321014221612504613210141612(e)50461210251422161

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论