- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十章 图和网络问题 10.1 图的遍历 10.2 网络流 10.3 二分图的最大匹配问题 10.1 图的遍历 图的遍历:从图的某个顶点出发,沿着与顶点相关 联的边,访问图中的所有顶点各一次。 两种方法:深度优先搜索和广度优先搜索。 10.1 图的遍历 10.1.1 图的深度优先搜索遍历 10.1.2 图的广度优先搜索遍历 10.1.3 无向图的接合点 10.1.4 有向图的强连通分支 10.1.1 图的深度优先搜索遍历 一、深度优先搜索(Depth First Search)的思想 方法 二、数据结构 三、深度优先搜索算法的步骤 四、算法实现 五、树边和后向边 六、时间复杂性 七、空间复杂性 一、思想方法 令 G V,E 是一个 有向图或无向图。 1、开始时,图 G 中的所有顶点都标记为未访问过。 2、从 G 中任选一点 u∈V 作为初始出发点,访问出发点 u,把 它标记为访问过, 3、从 u 出发,搜索 u 的下一个邻接顶点 v; 4、若 v 未被访问过,把它标记为访问过,并把 v 作为新的出发 点 u ,转 3,继续递归地进行深度优先搜索。 5、若 v 已被访问过,重新从 u 出发,选择另一个未经搜索过的 邻接顶点 w,并 w 把作为新的出发点 u,转3 ,继续递归地 进行深度优先搜索。 6、若 u 的所有顶点 v 都已访问过,就从 u 回溯到之前的顶点。 如果 u 是初始出发点,则结束搜索过程。 二、数据结构 1、用图的邻接表来表示图中各顶点及其关联边之间的关系: struct adj_list /* 邻接表结点的数据结构 */ int v; /* 邻接顶点的编号 */ struct adj_list *next; /* 下一个邻接顶点 */ ; typedef struct adj_list NODE; NODE node[n]; /* 图的邻接表 */ 二、数据结构 2、用两个数组,来登记各个顶点在遍历中被访问的顺序号: int pren[n]; /* 相应顶点的前序遍历的顺序号 */ int postn[n]; /* 相应顶点的后序遍历的顺序号 */ int tra[n]; /* 按遍历顺序存放的顶点序号 */ 三、深度优先搜索算法的步骤 1. 把所有顶点标记为未访问过; 2. 令 i 0; 3. 若顶点 I 未访问过,则调用 dfs i ,进行深度优先搜索; 4. i i+1;若 i n 转 3;否则,算法结束; 对于函数dfs i ,则步骤如下: 1. 把顶点i标记为访问过;使指针 p 初始化为顶点的邻接表的首元素; 2. 若 p 指针为空,函数运行结束;否则取该指针所指向的元素,设该元素顶点编号为 v; 3. 若顶点 v 已访问过,则不作处理;否则,调用 dfs v ; 4. 使指针 p 指向下一个邻接顶点,转 2; 四、算法实现 1. void traver_dfs NODE node[ ], int n, int pren[ ], int postn[ ], int tra[] 2. 3. int i,prefdn,postfdn,count; 4. BOOL *b new BOOL[n]; 5. prefdn 0; postfdn 0; count 0; 6. for i ;i n;i++ 7. b[i] FALSE; 8. for i 0;i n;i++ 9. if !b[i] 10. dfs i,node,n,pren,postn,b,prefdn,postfdn,tra, count ; 11. delete b; 12. 1. void dfs int v,NODE node[ ],int n,int pren[ ],int postn[ ], BOOL b[ ],int prefdn,int postfdn,int tra[ ],int count 2. 3. NODE *p; 4. b[v] TRUE; tra[count++] v; 5. pren[v] ++prefdn; 6. p node[v].next; 7. while p! NULL 8. if !b[p- v] 9. dfs p-v,node, n, pren, postn, b, prefdn, postfdn, tra, count ; 10. p p- next 11. 12. postn[v] ++postfdn; 13. 五、树边和后向边 1、是无向图: ? 树边(Tree edges):深度优先搜索生成树中的边。如果在搜索时,边 u,
文档评论(0)