- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                算法导论-复习笔记
                    《算法导论》复习笔记Chapter22基本图算法22.1-1有向图邻接链表,计算节点出度和入度的时间复杂度?O(V+E)开一个degree[]数组,大小为结点个数,复杂度O(V);遍历邻接链表,经过边uv时,计算出度degree[u]+=1,计算入度degree[v]+=1,复杂度O(E)22.1-4 将一个多图变成等价无向图,用邻接链表表示,时间复杂度O(V+E)多图是允许重复边和自循环边的图。开一个bool数组mark[],大小为节点个数,初始化为false。复杂度O(V)。对每个顶点u的邻接链表,遍历,令v为u的边所指向的顶点;如果mark[v]=false,将uv加入新图,并将mark[v]设置为true;否则就跳过。复杂度O(E)再次遍历u的连边,将mark[v]初始化整体复杂度O(V+E)伪代码:SOLVE(G,G’)1 for each vetex u∈G2for each v∈G.Adj[u]3 if mark[v]==false4 mark[v]==true5 Addedge(G’,u,v)6for each v∈G.Adj[u]7 mark[v]=false22.1-6 图G的邻接矩阵表示,给出一个O(V)的算法来判断有向图G中是否存在一个通用汇点。通用汇点指的是入度|V|-1,但出度为0。等价问题:给定有向图G的V×V邻接矩阵G,在O(V)时间内判断是否存在一个数k,使得对所有的i有A[i][k]=1,对所有的j有A[k][j]=0,(i≠k,j≠k)令i和j初值为1,若G[i][j]=0,说明i到j无边,j不可能是通用汇点,令j=j+1;若G[i][j]=1,说明i到j有边,i不可能是通用汇点,令i=i+1,循环直到i|V|或者j|V|;若i|V|,则不存在通用汇点,若j|V|,则检查顶点i是否满足要求。伪代码:判断是否存在通用汇点 O(V)HAS_UNIVERSL_SINK(G)1 i=j=12 while i≤V and j≤V3if G[i][j]==14 i=i+15 else j=j+16 if iV7 return false8 else return CHECK(G,i)CHECK(G,u)1 for each vertex v∈G.V2 if G[u][v]=13 return false4 for each vertex v ∈G.V5ifG[v][u]==0 u!=v6 return false7 return true检查点u是否是通用汇点【宽度优先搜索】22.2-2 计算无向图BFS后的d值和π值简单,注意初始节点u的π值写NIL或者写-1rstuvwxyD值swuNILrtuu22.2-4输入如果是邻接矩阵表示的,BFS的运行时间?O(V^2)对于队列中的每一个节点,都要遍历所有的节点来判断是否有边。22.2-6 举例说明一个有向图G中可能存在这样一个边集Eπ:s到v的唯一简单路径也是一条最短路径,但是无论如何该边集Eπ都不能通过在图G上运行BFS获得。V={1,2,3,4,5},E={(1,2),(2,3),(1,4),(4,5),(2,5),(3,4)}, Eπ={(1,2),(2,3),(1,4),(4,5)}, s=122.2-8 求一棵树T=(V,E)的直径,并分析算法的运行时间。直径指的是树中所有最短路径的最大值。两遍BFS就能解决.设v任意一点,BFS(v),令u=v能到达的最远点。再BFS(u),取w为u能达到的最远点,则u和w之间的最短路径就是直径。时间复杂度是O(V+E)。注意本题的证明。反证法,设t1到t2是直径,u是v能达到的最远点,但是u不是t1或者t2中的一个,产生矛盾的结论。【深度优先搜索】22.3-2 给出DFS每个结点的发现时间和完成时间,并给出每条边的分类qrstuvwxyzdis/fin1/1617/202/78/1518/193/64/59/1213/1410/11qssvvwwsqwqttxxzzxtyyqryuyru树边树边树边后向边前向边树边树边树边后向边树边后向边横向边横向边树边22.3-7用栈实现DFS,写出伪代码DFS-VISIT(G,u)1 STACK.PUSH(u)2 while(! STACK.empty)3 u=STACK.top4 if u.color==GRAY5 u.color==BLACK6 time=time+17 u.f=time8 STACK.POP9 continue10if u.color==WHITE11u.color=GRAY12time=time+113u.d=time14for each v∈G:Adj[u]15if v.color==WHITE16v.π=u17STACK
                 原创力文档
原创力文档 
                        

文档评论(0)