- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
专业课程设计图的遍历
目 录
一、课题的主要功能 3
1.1 设计内容 3
1.2 对课程设计功能的需求分析 . 3
二、课题的功能模块的划分 3
2.1 模块划分 3
2.2 系统的概要设计 4
三、主要功能的实现 5
3.1 算法思想 5
1. 图的邻接矩阵的建立 5
2. 图的遍历的实现 5
3.2 数据结构 5
3.3 主函数流程图 6
3.4 深度优先遍历流程图 . 7
3.5 深度优先遍历递归 9
3.6 深度优先遍历流程图 . 10
3.7 广度优先遍历递归流程图 . 12
四、程序调试 13
4.1 程序的调试分析 13
4.2 程序的测试结果 14
五、总结 . 18
六、附件 . 18
6.1 源程序 18
2
一、课题的主要功能
1.1 设计内容
演示图的深度优先 , 广度优先遍历过程, 并输出原图结构及遍历结果。 要求图的结
点数不能少于 6 个。可以由系统随机生成图, 也可以由用户手动输入图。报告中要写出
画图的思路;画出图的结构,有兴趣的同学可以进一步改进图的效果。
1.2 对课程设计功能的需求分析
图的遍历并不需要是一个过于复杂的工作环境,一般来说:最合适的才是最好的。
软件设计必须符合我们使用实际情况的需要。根据要求,图的遍历主要功能如下:
1.用户可以随时建立一个有向图或无向图;
2.用户可以根据自己的需要,对图进行深度遍历或广度遍历;
3.用户可以根据自己的需要对图进行修改;
在整个程序中 , 用户可以不断的按照不同的方式对图进行遍历 , 若不继续 , 用户也可以随时跳出程序 , 同时 , 如果用户输入的序号错误 , 程序会提示用户重新输入序号;
二、课题的功能模块的划分
2.1 模块划分
队列的初始化、进队、出队、队列空、队列满的函数
void InitQueue(CirQueue *Q) // 初始化队列
int QueueEmpty(CirQueue *Q)// 队列是否为空
int QueueFull(CirQueue *Q)// 队列满
Void EnQueue(CirQueue *Q,int x)// 将队员进队 int DeQueue(CirQueue *Q)// 将队员出队
创建图的函数
void CreateMGraph(MGraph *G)// 根据用户需要创建一个图
图的深度优先遍历递归
void DFSM(MGraph *G,int i)/* 含有输出已访问的顶点的语句 */
3
图的广度优先遍历递归
void BFSM(MGraph *G,int k) /* 含有输出已访问的顶点的语句 */
深度优先遍历
void DFSTraverseM(MGraph *G)/* 调用 DFSM函数 */
广度优先遍历
void BFSTraverseM(MGraph *G) /* 调用 BFSM函数 */
主函数
main() /* 包含一些调用和控制语句 */
2.2 系统的概要设计
开 始
信息录入
菜单选择
深
修
广
度
改
度
优
信
优
先
息
先
退出程序
4
三、主要功能的实现
3.1 算法思想
本课题所采用的是邻接矩阵的方式存储图, 实现图的深度、广度两种遍历,并将每
种遍历结果输出来。
1.图的邻接矩阵的建立
对任意给定的图(顶点数和边数自定) ,根据邻接矩阵的存储结构建立图的邻接距
阵。
2.图的遍历的实现
图的遍历包括图的广度优先遍历与深度优先遍历。 对于广度优先遍历应利用队列的五种基本运算(置空队列、进队、出队、取队头元素、判队空)来实现。首先建立一空
队列,从初始点出发进行访问,当被访问时入队,访问完出队。并以队列是否为空作为
循环控制条件。 对于深度优先遍历则采用递归或非递归算法来实现, 这里我所采用的是
递归算法。
3.2 数据结构
#define Max 10
#define FALSE 0
#define TRUE 1
#define Error printf
#define QueueSize 30
typedef struct
{
char vexs[Max];
int edges[Max][Max];
int n,e;
5
}MGraph;
int visited[Max];
typedef struct
{
int front;
int rear;
int count;
int data[QueueSize];
}CirQueue;
3.3 主函数流程图
登陆开始
6
您可能关注的文档
最近下载
- 食品经营(仅销售预包装食品)备案申请表-模板.pdf VIP
- 宁夏枣泉电厂一期工程的环境影响的报告书简本.doc VIP
- 2022年国家公务员录用考试行测常识题库及答案(共1344题).pdf VIP
- (人教PEP2024版)英语三年级上册全册大单元教学设计(新教材).docx
- 北京交通大学DSP系统课程设计报告电话拨号音检测.docx VIP
- 妇产科规培年度述职报告.docx VIP
- 【庄歌】黄沙坪矿区生产实习.doc VIP
- 2025届高考英语二轮复习:非谓语动词课件 (共49张PPT).ppt.pptx VIP
- 一种驱虫斑鸠菊提取物的外用制剂及其制备方法.pdf VIP
- 杭州优迈SMART系统中文标示电气原理图.pdf VIP
文档评论(0)