- 1、本文档共75页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
迷宫的路由与生成课程设计说明书
课程设计说明书
课 程 名 称: 数据结构与算法设计综合设计
课 程 代 码:
题 目: 迷宫的生成与路由
年级/专业/班:
学 生 姓 名:
学 号:
开 始 时 间: 年 月 日
完 成 时 间: 年 月 日
课程设计成绩:
平时学习
态度与效果
(30)
技术水平与
实际能力
(30)
团队协作与
技术创新
(10分)
设计说明书
撰写质量
(30)
总 分(100)
指导教师签名: 年 月 日
目 录
1 需求分析……………………………………………………………………1
2 概要设计……………………………………………………………………3
3详细设计……………………………………………………………………9
4调试分析……………………………………………………………………20
5用户使用说明………………………………………………………………22
6测试结果……………………………………………………………………24
7 结论………………………………………………………………………26
致谢……………………………………………………………………………29
参考文献………………………………………………………………………30
摘 要
用C++语言编写的生成一个N×M(N行M列)的迷宫,完成迷宫的组织和存储,并实现迷宫路由算法。(1)使用二维数组matrix[M][N]表示迷宫,其中M,N为迷宫的行、列数,当元素值为0时表示该点是通路,当元素值为1时表示该点是墙。在每一点都有4种方向可以走,可以用数组wall[4]来表示每一个方向上的墙,用另一个二维数组graph[M][N]记录墙和节点的情况。(2)选用深度优先算法和广度优先算法寻找路径,迷宫由程序自动创建。
关键词:迷宫生成、广度优先、深度优先
引 言
1 需求分析
设计算法生成一个N*M(N 行M 列)的迷宫,并完成迷宫的组织和储存。实现两种不同的迷宫算法:广度优先,深度优先算法。
要求:
1.N 和M 是用户可配置的,缺省值为50 和50。
2.迷宫的入口和出口分别在第0行和第N-1行上,随机选择。
3.生成迷宫要求是随机,且连通的。
4. 迷宫具有多条分支路线 。
5. 进行深度优先探索迷宫路径并进行输出。
6. 进行广度优先探索迷宫路径并进行输出。
7.实现图形化界面显示。
8. 在图形界面输出寻路过程坐标。
8. 实现按钮事件处理的图形用户界面交互。
1.1任务与分析
随机生成一个迷宫(由用户规定其大小)并使用。算法分析迷宫是连通的。使用图形表示,并分别在迷宫的第一行和最后一行随机选择出口和入口,输出可通迷宫的最佳路径。
任务一:迷宫随机生成算法的实现。
任务二:迷宫深度.优先搜索算法实现。
任务三:迷宫广度优先搜索算法实现。
任务三:进行图形界面的表示。
分析:
对三大主要功能模块进行三大主类设计,分别为Maze类,DFS类,BFS类,
最后使用MFC应用程序进行图形界面的表示。
1.2测试数据
m, n 取默认值50,50
m, n 取默认值20,20
m, n 取默认值60, 60
2 概要设计
(此处说明本课程设计题目的模块划分及各模块的功能介绍和对应的函数名(原型)以及各模块间的层次(调用)关系―――以框图描述)
本系统所设计的函数见表2.1
MazeCell类
函数名称
函数原型
功能描述
MazeCell
MazeCell();
迷宫格对象初始化。
Maze类
函数名称
函数原型
功能描述
Maze
Maze(int m = 49, int n = 49)
初始化迷宫行数和列数,构造节点矩阵
createMaze
void createMaze()
随机创建课连通迷宫
printMaze
void printMaze()
在DOS界面打印迷宫
hasUnaccessAdjNode
bool hasUnaccess
AdjNode(int,int)
判断下一节点是否可以访问
breakWall
void breakWall(MazeCell*)
拆掉墙,使两节点连通
toNextNode
void toNextNode()
移动当前节点到下一节点
makeRomdanStartAndEnd
void makeRomdan
StartAndEnd()
随机生成入口和
您可能关注的文档
最近下载
- 吻合器应用的有关问题.ppt
- 2024秋国开《法律职业伦理》形考任务一至三答案.docx VIP
- 《党政机关厉行节约反对浪费条例》详细内容学习(PPT+文稿).pptx VIP
- 油库DCS控制系统.pptx VIP
- 世界职业院校技能大赛「参赛项目介绍内容」模拟示例参考—项目名称:生命之桥.docx VIP
- (新平台)国家开放大学《幼儿园教育质量评价》形考任务1-3参考答案.pdf VIP
- 上海交通大学网络护理管理学习题册答案.pdf VIP
- 液化气公司(燃气站)安全生产三项制度完整版.doc VIP
- 生物质发电锅炉设备原理方案.doc
- 2025年《党政机关厉行节约反对浪费条例》PPT学习课件.pptx VIP
文档评论(0)