- 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;若 in 转 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=;in;i++) 7. b[i] = FALSE; 8. for (i=0;in;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;
您可能关注的文档
最近下载
- 2024年北京西城区卫生健康系统事业单位招聘笔试真题汇总.docx VIP
- 初三物理第十八章电功率复习-(精品课件).ppt VIP
- 全国行政执法人员执法资格考试必考题库及参考答案(通用版).docx
- 标准方管和矩形管尺寸及参考价格.pdf VIP
- 无人机考试题库(全真题库)附参考答案(达标题).docx VIP
- 西门子(SIEMENS)FUE380FUS380超声波流量计说明书.pdf
- DLT817-2014 立式水轮发电机检修技术规程.docx VIP
- ACS6000变频器整流单元更换方法培训课件.ppt VIP
- GB50854-2013 房屋建筑与装饰工程工程量计算规范.docx VIP
- 统编版六年级上册语文文言文阅读专题训练(有答案).pdf VIP
文档评论(0)