- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
目 录
一、课题的主要功能 2
1.1 设计内容 2
1.2 对课程设计功能的需求剖析 2
二、课题的功能模块的区分 . 2
2.1 模块区分 2
2.2 系统的纲要设计 3
三、主要功能的实现 4
3.1 算法思想 4
1. 图的邻接矩阵的成立 4
2. 图的遍历的实现 4
3.2 数据构造 4
3.3 主函数流程图 5
3.4 深度优先遍历流程图 6
3.5 深度优先遍历递归 7
3.6 深度优先遍历流程图 8
3.7 广度优先遍历递归流程图 9
四、程序调试 11
4.1 程序的调试剖析 11
4.2 程序的测试结果 11
五、总结 15
六、附件 16
6.1 源程序 16
一、课题的主要功能
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)/* 含有输出已接见的极点的语句 */
图的广度优先遍历递归
void BFSM(MGraph *G,int k) /* 含有输出已接见的极点的语句 */
深度优先遍历
void DFSTraverseM(MGraph *G)/* 调用 DFSM函数 */
广度优先遍历
void BFSTraverseM(MGraph *G) /* 调用 BFSM函数 */
主函数
main() /* 包含一些调用和控制语句 */
2.2 系统的纲要设计
开 始
信息录入
菜单项选择择
深
修
广
度
改
度
优
信
优
先
息
先
退出程序
三、主要功能的实现
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;
}MGraph;
int visited[Max];
typedef struct
{
int front;
int rear;
int count;
int data[QueueSize];
}CirQueue;
3.3 主函数流程图
登岸开始
CreateMGraph
(G);
Ch1=’y’
Ch1=’y’
真
假
Ch2
0
1
2
3
结束程序
Ch1=’n’
CreateMGraph(G)
DFSTraverseM(G) B r e a k
BFSTraverseM(G)
3.4 深度优先遍历流程图
DFSTraverseM(MGraph *G)
i=0
您可能关注的文档
最近下载
- 企业吸收合并协议.doc VIP
- 板框压滤机操作规程.doc VIP
- 义务教育版七年级全一册信息科技 第9课 数据传输有新意 教案(表格式).pdf VIP
- 爬山虎的脚PPT课件.pptx
- 康复辅助技术咨询师.pdf VIP
- 北京工业大学822信号与系统2022年真题及答案.pdf VIP
- 全国黄金交易从业水平考试《黄金市场基础知识与交易实务》复习全书【核心讲义+章节练习】.docx VIP
- 电饭煲UL认证零部件检验要求.pdf VIP
- 浙江省桐乡市2025年上半年公开招聘辅警试题含答案分析.docx VIP
- GB30871危险化学品企业位特殊作业安全规范知识考试复习题库(含答案).docx VIP
文档评论(0)