欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    图的遍历源代码.docx

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

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

    图的遍历源代码.docx

    图的遍历源代码图的遍历顺序有两种:深度优先搜索和广度优先搜索。深度优先遍历的基本思想是:首先从图中某个顶点v0出发,访问此顶点,然后依次从v0相邻的顶点出发深度优先遍历,直至图中所有与v0路径相通的顶点都被访问了;若此时尚有顶点未被访问,则从中选一个顶点作为起始点,重复该步骤直到所有的顶点都被访问。而广度优先遍历首先从图的某个顶点v0出发,访问了v0之后,依次访问与v0相邻的未被访问的顶点,然后分别从这些顶点出发,广度优先遍历,直至所有的顶点都被访问完。 流程图如下: 程序代码如下: #include<iostream> #include<process.h> #include<stdlib.h> #define MaxVerNum 50 using namespace std; struct edgenode int endver; int inform; edgenode* edgenext; ; struct vexnode char vertex; edgenode* edgelink; ; struct Graph vexnode adjlistsMaxVerNum; int vexnum; int arcnum; ; /队列的定义及相关函数的实现 struct QueueNode int nData; QueueNode* next; ; struct QueueList QueueNode* front; QueueNode* rear; ; void EnQueue(QueueList* Q,int e) QueueNode *q=new QueueNode; q->nData=e; q->next=NULL; if(Q=NULL) return; if(Q->rear=NULL) Q->front=Q->rear=q; else Q->rear->next=q; Q->rear=Q->rear->next; void DeQueue(QueueList* Q,int* e) if (Q=NULL) return; if (Q->front=Q->rear) *e=Q->front->nData; Q->front=Q->rear=NULL; else *e=Q->front->nData; Q->front=Q->front->next; /创建图 void CreatAdjList(Graph* G) int i,j,k; edgenode* p1; edgenode* p2; cout<<"请输入顶点数和边数:"<<endl; cin>>G->vexnum>>G->arcnum; cout<<"开始输入顶点表:"<<endl; for (i=0;i<G->vexnum;i+) cin>>G->adjlistsi.vertex; G->adjlistsi.edgelink=NULL; cout<<"开始输入边表信息:"<<endl; for (k=0;k<G->arcnum;k+) cout<<"请输入各边对应的顶点<Vi,Vj>:" cin>>i>>j; p1=new edgenode; p1->endver=j; p1->edgenext=G->adjlistsi.edgelink; G->adjlistsi.edgelink=p1; p2=new edgenode; p2->endver=i; p2->edgenext=G->adjlistsj.edgelink; G->adjlistsj.edgelink=p2; /因为是无向图,所以有两次建立边表的过程 /-深度优先遍历 void DFS(Graph *G,int i,int visit) cout<<G->adjlistsi.vertex<<" " visiti=1; edgenode *p=new edgenode; p=G->adjlistsi.edgelink; if(G->adjlistsi.edgelink&&!visitp->endver) DFS(G,p->endver,visit); void DFStraversal(Graph *G,char c)/深度优先遍历 cout<<"该图的深度优先遍历结果为:"<<endl; int visitMaxVerNum; for(int i=0;i<G->vexnum;i+) visiti=0;/全部初始化为0,即未访问状态 int m; for (i=0;i<G->vexnum;i+) if (G->adjlistsi.vertex=c)/根据字符查找序号 m=i; DFS(G,i,visit); break; /继续访问未被访问的结点 for(i=0;i<G->vexnum;i+) if(visiti=0) DFS(G,i,visit); cout<<endl; /-广度优先遍历 void BFS(Graph* G,int v,int visit) QueueList *Q=new QueueList; Q->front=Q->rear=NULL; EnQueue(Q,v); while(Q->rear!=NULL) int e=0; DeQueue(Q,&e); cout<<G->adjlistse.vertex<<" " visite=1; edgenode* p=new edgenode; p=G->adjlistse.edgelink; if(p) int m=p->endver; if(m=0) EnQueue(Q,m); while(visitm=0) p=p->edgenext; if(p=NULL) break; m=p->endver; EnQueue(Q,m); void BFStraversal(Graph *G,char c) cout<<"该图的广度优先遍历结果为:"<<endl; int visitedMaxVerNum; for (int i=0;i<G->vexnum;i+) visitedi=0; int m; for (i=0;i<G->vexnum;i+) if (G->adjlistsi.vertex=c) m=i; BFS(G,i,visited); break; /继续访问未被访问的结点 for(i=0;i<G->vexnum;i+) if(visitedi=0) BFS(G,i,visited); cout<<endl; void main system("color 75"); /设置颜色以美观 Graph * G=new Graph; CreatAdjList(G); char ch; cout<<"请输入开始遍历的顶点:" cin>>ch; DFStraversal(G,ch); BFStraversal(G,ch); 程序运行结果如下图:

    注意事项

    本文(图的遍历源代码.docx)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

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




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开