




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
图的遍历1题目题目:编写一个程序,实现图的遍历运算,并在此基础上设计一个主程序完成如下功能:输出如图的有向图G从顶点0开始的深度优先遍历序列(递归算法)。输出如图的有项图G从顶点0开始的深度优先遍历序列(非递归算法)。输出如图的有向图G从顶点0开始的广度优先遍历序列 01234554319765582 目标 熟悉图的定义及其基本操作的实现。3 设计思想 图的输入采用邻接矩阵的形式,在程序内部以邻接表形式进行操作。将上图进行深度优先遍历和广度优先遍历。4 算法描述(1) 邻接矩阵转换为邻接表:邻接表的结点元素是由结点组成的矩阵两个计数量。把邻接矩阵的结点数据值赋值给邻接表元素结点的数据变量,并初始化其元素结点指针为空;测试邻接矩阵的非零位,若为1则在邻接表中使前一个结点指向后一个结点。(2) 广度优先遍历:数组visited标记结点是否被访问,初始化为全零;从结点Vi开始访问,访问此顶点后,依次访问Vi的各个未曾访问过的邻接点,然后分别从这些邻接点出发,直至图中所有已有已被访问的顶点的邻接点都被访问到。(3) 深度优先遍历:深度优先遍历可有两种方式,递归和非递归。其中递归的深度优先遍历的思想是首先访问出发点v,并将其标记为已访问过;然后依次从v出发搜索v的每个邻接点w。若w未曾访问过,则以w为新的出发点继续进行深度优先遍历,直至图中所有和源点v有路径相通的顶点(亦称为从源点可达的顶点)均已被访问为止。若此时图中仍有未访问的顶点,则另选一个尚未访问的顶点作为新的源点重复上述过程,直至图中所有顶点均已被访问为止。5 程序结构图开始main( )初始化图转换邻接矩阵为邻接表广度优先遍历深度优先遍历(递归)深度优先遍历(非递归)结束6 源程序#include#include#include #define MAXVEX 100typedef char VertexType3;typedef struct edgenode int adjvex; int value; struct edgenode *next;ArcNode;typedef struct vexnode VertexType data; ArcNode *firstarc;VHeadNode;typedef struct vertex int adjvex;VertexType data;VType;typedef struct graph int n,e;VType vexsMAXVEX;int edges MAXVEXMAXVEX;AdjMatix;typedef struct int n,e; VHeadNode adjlistMAXVEX;AdjList;/将邻接矩阵g转化成邻接表G:void MatToList(AdjMatix g, AdjList *&G) int i,j; ArcNode *p; G=(AdjList *)malloc(sizeof(AdjList); for (i=0;iadjlisti.firstarc=NULL; strcpy( G-adjlisti.data,g.vexsi.data); for (i=0;i=0;j-) if (g.edgesij!=0) p=(ArcNode *)malloc(sizeof(ArcNode); p-value=g.edgesij;p-adjvex=j; p-next=G-adjlisti.firstarc; G-adjlisti.firstarc=p; G-n=g.n;G-e=g.e;/广度优先:void BFS(AdjList *G,int vi) int i,v,visitedMAXVEX; int QuMAXVEX,front=0,rear=0; ArcNode *p; for (i=0;in;i+) visitedi=0;printf(%d,vi);visitedvi=1;rear=(rear+1)%MAXVEX;Qurear=vi;while(front!=rear) front=(front+1)%MAXVEX; v=Qufront; p=G-adjlistv.firstarc; while(p!=NULL) if(visitedp-adjvex=0) visitedp-adjvex=1; printf(%d,p-adjvex); rear=(rear+1)%MAXVEX; Qurear=p-adjvex; p=p-next; /深度优先递归:int visitedMAXVEX;void DFS(AdjList *g,int vi) ArcNode *p; printf(%d,vi); visitedvi=1; p=g-adjlistvi.firstarc; while(p!=NULL) if (visitedp-adjvex=0) DFS(g,p-adjvex); p=p-next; /深度优先非递归:void DFS1(AdjList *G,int vi) ArcNode *p; ArcNode *StMAXVEX; int top=-1,v; printf(%d,vi); visitedvi=1; top+; Sttop=G-adjlistvi.firstarc; while(top-1) p=Sttop;top-; while(p!=NULL) v=p-adjvex; if(visitedv=0) printf(%d,v); visitedv=1; top+; Sttop=G-adjlistv.firstarc; break; p=p-next; void main() int i,j; AdjMatix g; AdjList *G; int a66=0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,1,0,0,1,0,0,1,0,0,0,1,0,0,1,0,0,0,1,0; char *vnameMAXVEX=a,b,c,d,e,f; g.n=6;g.e=10; for(i=0;ig.n;i+) strcpy(g.vexsi.data,vnamei); for(i=0;ig.n;i+) for(j=0;jg.n;j+) g.edgesij=aij; MatToList(g,G); printf(从顶点0的广度优先遍历序列:n); printf(t);BFS(G,0); printf(n);for(i=0;ig.n;i+)visitedi=0;printf(从顶点0的深度优先遍历序列:n);printf(递归算法:);DFS(G,0);printf(n);for(i=0;i10)要求编写C程实现时应该考虑边界条件的处理。2 目的掌握大数的处理方法。3 设计思想由于阶乘数据一般较大,因此用整形数组来存储结果,数组的每一元素是结果数字的某一位。计算时从低位开始,依次从2开始乘,每乘一位计算其进位,加到高位中去。4 程序流程图NY开始carry=0i=2i=ntemp=resultj-1*i+carryresultj-1=temp%10arrayi=temp%10i+结束5 源程序#include #include void factorial(int * result,int n)int carry,digit=1,temp; result0=1;for(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年人力资源专员招聘笔试备考要点与试题集
- 2025年站台安全门系统项目建议书
- 2025年金属波纹管膨胀节(钢)项目发展计划
- 2025年经济与商务咨询服务项目合作计划书
- 2025年年化妆品原料合作协议书
- 2025年抗滴虫病药项目建议书
- 2025年虚拟轴坐标测量机合作协议书
- 2025年行李自动分检系统项目发展计划
- 2025年手工制纸及纸板项目发展计划
- 2025年植物施药保护机械项目发展计划
- 主题思政课铸牢中华民族共同体意识
- 邮政行业痛点与解决措施
- 二年级《劳动最光荣》课件
- 帕夫雷什中学
- 2023年人教版美术六年级上册全册教案
- 道路交通安全法知识试题库完整
- 《铁路交通事故调查处理规则》解读
- 研究生学术行为规范讲座
- 水资源论证水土保持防洪评价收费标准
- 年处理12万吨煤焦油加工工艺初步设计
- 烟化炉车间技术操作规程-附一:烟化炉开炉、停炉、故障处理及正常操作原则
评论
0/150
提交评论