- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
单击此处添加大标题内容继续向生成树上添加顶点;voidMiniSpanTree_P(MGraphG,VertexTypeu){//用普里姆算法从顶点u出发构造网G的最小生成树k=LocateVex(G,u);for(j=0;jG.vexnum;++j)//辅助数组初始化if(j!=k)closedge[j]={u,G.arcs[k][j].adj};closedge[k].lowcost=0;//初始,U={u}for(i=0;iG.vexnum;++i){}单击此处添加大标题内容k=minimum(closedge);//求出加入生成树的下一个顶点(k)printf(closedge[k].adjvex,G.vexs[k]);//输出生成树上一条边closedge[k].lowcost=0;//第k顶点并入U集for(j=0;jG.vexnum;++j)//修改其它顶点的最小边if(G.arcs[k][j].adjclosedge[j].lowcost)closedge[j]={G.vexs[k],G.arcs[k][j].adj};克鲁斯卡尔Kruskal算法基本思想:具体做法:先构造一个只含n个顶点的子图SG,然后从权值最小的边开始,若它的添加不使SG中产生回路,则在SG上加上这条边,如此重复,直至加上n-1条边为止。考虑问题的出发点:为使生成树上边的权值之和达到最小,则应使生成树中每一条边的权值尽可能地小。abcdegf195141827168213ae12dcbgf7148531621例如:7121819算法描述:构造非连通图ST=(V,{});k=i=0;//k计选中的边数while(kn-1){++i;检查边集E中第i条权值最小的边(u,v);若(u,v)加入ST后不使ST中产生回路,则输出边(u,v);且k++;}普里姆算法01克鲁斯卡尔算法02时间复杂度03O(n2)04O(eloge)05稠密图06稀疏图07算法名08适应范围09比较两种算法10添加标题添加标题添加标题添加标题重(双)连通图和关节点若从一个连通图中删去任何一个顶点及其相关联的边,它仍为一个连通图的话,则该连通图被称为重(双)连通图。问题:割点如何判别给定的连通图是否是双连通图?若连通图中的某个顶点和其相关联的边被删去之后,该连通图被分割成两个或两个以上的连通分量,则称此顶点为关节点。没有关节点的连通图为双连通图。ahgcbfdeabcdefgh1234567833111111例如:下列连通图中,顶点a和顶点c是关节点深度优先生成树关节点有何特征?需借助图的深度优先生成树来分析。假设从某个顶点V0出发对连通图进行深度优先搜索遍历,则可得到一棵深度优先生成树,树上包含图的所有顶点。若生成树的根结点,有两个或两个以上的分支,则此顶点(生成树的根)必为关节点;对生成树上的任意一个“顶点”,若其某棵子树的根或子树中的其它“顶点”没有和其祖先相通的回边,则该“顶点”必为关节点。对上述两个判定准则在算法中如何实现?设V0为深度优先遍历的出发点p=G.vertices[0].firstarc;v=p-adjvex;DFSArticul(G,v);//从第v顶点出发深度优先搜索if(countG.vexnum){//生成树的根有至少两棵子树printf(0,G.vertices[0].data);//根是关节点定义函数:low(v)=Min{visited[v],low[w],visited[k]}其中:顶点w是生成树上顶点v的孩子;顶点k是生成树上和顶点v由回边相联接的祖先;visited记录深度优先遍历时的访问次序若对顶点v,在生成树上存在一个子树根w,且low[w]≥visited[v]则顶点v为关节点。对深度优先遍历算法作如下修改:遍历过程中求得low[v]=Min{visited[v],low[w],visited[k]}从子树遍历返回时,判别low[w]≥visited[v]?visited[v]的值改为遍历过程中
您可能关注的文档
- 旅游卫视城市形象宣传.ppt
- 某公司薪资调整建议方案.ppt
- 小学四年级上册语文第三十一课飞向蓝天的恐龙.ppt
- 小学语文三年级下册第一板块汉字家园第二.ppt
- 手机原理与常见故障排除.ppt
- 教育心理学第八章学习策略.ppt
- 小学语文六年级下册学会生存课件.ppt
- 数字影视创意及剧本写作.ppt
- 数据库原理与SQLServer.ppt
- 旅游心理学第一二次.ppt
- 福莱特玻璃集团股份有限公司海外监管公告 - 福莱特玻璃集团股份有限公司2024年度环境、社会及管治报告.pdf
- 广哈通信:2024年度环境、社会及治理(ESG)报告.pdf
- 招商证券股份有限公司招商证券2024年度环境、社会及管治报告.pdf
- 宏信建设发展有限公司2024 可持续发展暨环境、社会及管治(ESG)报告.pdf
- 品创控股有限公司环境、社会及管治报告 2024.pdf
- 中信建投证券股份有限公司2024可持续发展暨环境、社会及管治报告.pdf
- 洛阳栾川钼业集团股份有限公司环境、社会及管治报告.pdf
- 361度国际有限公司二零二四年环境、社会及管治报告.pdf
- 中国神华能源股份有限公司2024年度环境、社会及管治报告.pdf
- 广西能源:2024年环境、社会及治理(ESG)报告.pdf
文档评论(0)