欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载  

    求欧拉回路的Fleury算法.doc

    • 资源ID:5656929       资源大小:26.50KB        全文页数:5页
    • 资源格式: DOC        下载积分:2
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要2
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    求欧拉回路的Fleury算法.doc

    一、 实验内容:判断图G是否存在欧拉回路,若存在,输出其中一条欧拉回路。否则,显示无回路。二、 实验过程与结果1. 问题简介:通过图(无向图或有向图)中所有边一次且仅一次行遍所有顶点的回路称为欧拉回路。具有欧拉回路的图称为欧拉图2. 算法思想(框图):(1)任取v0V(G),令P0=v0.(2)设Pi=v0e1v1e2eivi已经行遍,按下面方法来从E(G)-e1,e2,ei中选取ei+1:(a)ei+1与vi相关联;(b)除非无别的边可供行遍,否则ei+1不应该为Gi=G-e1,e2,ei中的桥。(3)当(2)不能再进行时,算法停止。 可以证明,当算法停止时所得简单回路Pm=v0e1v1e2emvm(vm=v0)为G中一条欧拉回路。3. 数据输入: 边数5,点数6 相关联的点1 2 1 3 2 5 4 2 3 2 4 54. 运行结果:存在欧拉回路 1,3,2,4,5,2,15. 分析总结:Fleury算法是求欧拉图的十分有效的算法,在执行过程中需要用到类似于图的深度优先遍历,因为该算法就是需要将已找到的路径不断的扩展下去,直到将所有边扩展进路径。判断是否为欧拉图(连通性和奇度点)图 输出无欧拉回路0=V0=1Pi=v0e1v1eivi,ei+1E(G)-e1,eiei+1与vi关联,i=i+1,ei+1非桥Y输出欧拉回路Pm=v0e1v1e2emvm(vm=v0)E(G)-e1,e2,ei= Fleury算法流程图三、 完整源程序#include <iostream.h>#include <stdio.h>#include <string.h>struct stackint top , node81; T,F,A; /顶点的堆栈int M8181; /图的邻接矩阵int n;int degree81;bool brigde(int i,int j) int flag81,t,s; for(s=1;s<=n;s+) flags=0; if(degreei=1)return false; else Mij=0;Mji=0;A.top=1;A.node1=i;flagi=1;t=i;while(A.top>0) for(s=1;s<=n;s+) if(degrees>0) if(Mts=1) if(flags=0) A.top+; A.nodeA.top=s; flags=1;t=s;break; if(s>n) A.top-; t=A.nodeA.top; for(s=1;s<=n;s+) if(degrees>0) if(flags=0) Mij=Mij=1; return true; break; if(s>n) return false; void Fleury(int x) /Fleury算法 int i,b=0; if(T.top<=n+1) T.top+;T.nodeT.top=x; for(i=1;i<=n;i+) if(Mxi=1)if(brigde(x,i)=false)b=1;break;if(b=1)Mxi=Mix=0;degreex-;degreei-;Fleury(i); void main() int m , s , t , num , i , j,flag81; /input cout<<"nt输入顶点数和边数:" cin>>n>>m;/n顶点数 m边数 memset(M , 0 , sizeof(M); for (i = 1; i <=n; i +) degreei=0; for (i = 0; i < m; i +) cout<<"ntt输入第"<<i+1<<"边的顶点:"cin>>s>>t; Mst = 1; Mts = 1; degrees=degrees+1; degreet=degreet+1; /判断是否存在欧拉回路for(i=1;i<=n;i+)flagi=0; s = 0;/判断是否连通F.top=1;F.node1=1;flag1=1;t=1;for(j=2;j<=n;j+)if(Mtj=1)F.top+;F.nodeF.top=j;flagj=1;t=j;break; if(j>n) s=1; else while(F.top<=n&&F.top>=1) for(j=2;j<=n;j+) if(Mtj=1) if(flagj=0) F.top+; F.nodeF.top=j; flagj=1;t=j;break; if(j>n) F.top-; t=F.nodeF.top; for(i=1;i<=n;i+) if(flagi=0) s=1; break; if(s=0) /判断有无奇度点 for (i = 1; i <= n; i +)num = 0;for (j = 1; j <= n; j +)num += Mij;if (num % 2 = 1) s +; break; if (s = 0) T.top=0;Fleury(1);cout<<"nt该图的一条欧拉回路:"for(i=1;i<=m+1;i+) cout<<T.nodei<<" " else cout<<"nt该图不存在欧拉回路!n"

    注意事项

    本文(求欧拉回路的Fleury算法.doc)为本站会员(苏美尔)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开