数据结构课程设计报告——可视化走迷宫游戏

上传人:公**** 文档编号:431602613 上传时间:2023-04-12 格式:DOC 页数:45 大小:908.63KB
返回 下载 相关 举报
数据结构课程设计报告——可视化走迷宫游戏_第1页
第1页 / 共45页
数据结构课程设计报告——可视化走迷宫游戏_第2页
第2页 / 共45页
数据结构课程设计报告——可视化走迷宫游戏_第3页
第3页 / 共45页
数据结构课程设计报告——可视化走迷宫游戏_第4页
第4页 / 共45页
数据结构课程设计报告——可视化走迷宫游戏_第5页
第5页 / 共45页
点击查看更多>>
资源描述

《数据结构课程设计报告——可视化走迷宫游戏》由会员分享,可在线阅读,更多相关《数据结构课程设计报告——可视化走迷宫游戏(45页珍藏版)》请在金锄头文库上搜索。

1、44 西安建筑科技大学课程设计(论文)西安建筑科技大学课程设计(论文)题 目: 可视化走迷宫游戏 院 (系): 专业班级: 姓 名: 学 号: 指导教师: 2011年9月15日第8页(共38页)西安建筑科技大学课程设计(论文)任务书专业班级: 计算机901 学生姓名: 指导教师(签名): 一、课程设计(论文)题目走迷宫游戏:程序开始运行时显示一个迷宫地图,迷宫中央有一只老鼠,迷宫的右下方有一个粮仓。游戏的任务是使用键盘上的方向键操纵老鼠在规定的时间内走到粮仓处。二、本次课程设计(论文)应达到的目的数据结构是实践性很强的课程。课程设计是加强学生实践能力的一个强有力手段。课程设计要求学生在完成程序

2、设计的同时能够写出比较规范的设计报告。严格实施课程设计这一环节,对于学生基本程序设计素养的培养和软件工作者工作作风的训练,将起到显著的促进作用。本题目要达到目的:熟练掌握最短路径的算法设计。 三、本次课程设计(论文)任务的主要内容和要求(包括原始数据、技术参数、设计要求等) 1、 老鼠形象可辨认,可用键盘操纵老鼠上下左右移动;2、 迷宫的墙足够结实,老鼠不能穿墙而过;3、 正确检测结果,若老鼠在规定时间内走到粮仓处,提示成功,否则提示失败;4、 添加编辑迷宫功能,可修改当前迷宫,修改内容:墙变路、路变墙;找出走出迷宫的所有路径,以及最短路径。四、应收集的资料及主要参考文献: 由于本课程没有安排

3、“课内上机”学时,因此,在课程设计之前必须自己已经上机练习了“线性表”的基本操作。 参考文献:1. 本年级使用的教材:数据结构与算法分析(C+版)(第二版)影印版 2005.72. 数据结构与算法,科学出版社,2005.08;赵文静 祁飞等编著3. 数据结构-C+语言描述,西安交通大学出版社,1999.01,赵文静编著4. Visual C+编程实例(任意一本此类书籍)五、审核批准意见教研室主任(签字) 摘要本设计是为了实现一个可视化迷宫,以及利用最短路径算法寻找迷宫的出路以及将最短路径打印在屏幕上,并且限制小老鼠不能穿越墙,只能在路径上移动。而且可以根据自己的需要设计迷宫地图。关键词:mfc

4、 目 录一设计目的.1二问题描述.1三需求分析.1四概要设计.2五详细设计.4六测试分析.27七使用说明.36八总结.37九参考文献.38数据结构课程设计二叉树的遍历及树与二叉树的转换一设计目的通过课程设计,巩固所学的理论知识,培养综合运用所学知识解决实际问题的能力。能根据实际问题的具体情况,结合数据结构课程中的基本理论和基本算法,正确分析出数据的逻辑结构,合理地选择相应的存储结构,并能设计出解决问题的有效算法。二问题描述1.地图要求:根据要求构造一个迷宫地图,并且是老鼠清晰可见,可用键盘操纵老鼠上下左右移动;有一个窗口显示部分地图,另一个窗口显示全部题图。2.操作:老鼠不能穿墙而过,当老鼠到

5、达粮仓提示成功。可以自动找到迷宫的所有路径以及画出最短路径。三需求分析 1.利用mfc可以把迷宫地图以及老鼠形象可变的画出来。 2.需要有墙有路,通过把迷宫地图划分成一个一个小方块,通过一个数组的值来判断是墙是路。(1表示墙0表示路) 3通过鼠标事件控制老鼠的移动。 4把每个数组元素对应一个按钮根据点击按钮,改变数组的值从而改变墙和路的转化。四概要设计操作界面迷宫路径的搜索最短路径的显示全图与部分的同步小老鼠键盘操作用户的登陆界面游戏级别的选择编辑迷宫地图游戏音乐的设置地图的绘制开始结束 图1 程序界面图4.1、操作界面利用mfc单文档初始化界面,设置meau选项,以及分割成大小两个窗口。4.

6、2、用户的登陆界面利用对话框设计用户登陆界面,界面包括用户名,选择的迷宫级别。4.3、地图的绘制根据登陆界面的上面的信息,绘制迷宫地图。选择加载全图菜单会显示迷宫总图。4.4、游戏音乐的设置在迷宫加载之后,播放背景音乐,利用多线程异步播放。4.5、小老鼠键盘操作 利用键盘事件,完成小老鼠的操作。4.6、全图与部分的同步 利用CFrameWnd类实现两个view类的同步操作。4.7、搜索迷宫路径及最短路径的显示 选择路径菜单利用递归搜索出迷宫所有路径并且把最短路径绘制在全图显示中。4.8、编辑迷宫地图利用对话框中每一个按钮对用迷宫的一部分,编辑迷宫地图。4.9、层次序遍历算法按照树的层次从左到右

7、访问树的结点,层序遍历用于保存结点的容器是队列。void LevelOrder(BiNode root)。4.10、树与二叉树的转换算法转换时结点的第一个孩子变为它的左孩子,兄弟节点变为他的有孩子。void exchange(),class Tree。4.11、结束界面利用选继续还是结束游戏作为结束画面,点击继续级别将自动加1.五详细设计5.1、各模块流程图 新建登陆logdlg类对象,并且显示出来根据选择的级别初始化对应迷宫数组根据对应的迷宫数组初始化迷宫地图,同时初始化背景音乐,并且把玩家信息显示出来存入文件play.txt中。点击开始按钮 图1 游戏界面显示 开始NY按下键盘按方向键up

8、方向键down方向键left方向键right判断对应m_maze是否为0判断是否到达粮仓根据对应的操作老鼠进行相应的修改m_x,m_yNN结束YY 图2 小老鼠操作键盘事件利用CFrameWnd对象在部分图view类创建全图view类对象利用已建立的全图view类对象根据键盘事件部分图中小老鼠的位置变化m_xx,m_yy修改其类中小老鼠的位置m_x,m_y实现全图与部分图的同步图3、全图与部分图的同步 点击路径菜单Y搜索迷宫当前位置上下左右对应数组的数值m_mazei-1j=0orm_mazei+1j=0orm_mazeij-1=0orm_mazejj+1=0orm_mazei-1j=0orm

9、_mazei+1j=0orm_mazeij-1=0ormazejj+1=0orm_mazeij=-1,表示已经遍历过的路;把对应的数组i,j,direct添加到结构体中判断是否到达粮仓m_maze818=0)YYN把结构体数组的内容添加到maze.txt中比较得出最短路径,利用drawmaze()画出最短路径 图4、迷宫路径以及最短路径点击编辑迷宫菜单Y 图5、后序递归遍历开始申请一个BiNode 数组 int top=0判断结点是否空输出结点值s+top=root结点的值变为它的左孩子判数组是否空root=stop-root=root-rchild结束判数组或结点是否空NYNYN 图6、前序

10、非递归遍历开始申请一个BiNode 数组 int top=0判断结点是否空s+top=root 结点的值变为它的左孩子判数组是否空输出结点值root=stop-root=root-rchild结束判数组或结点是否空NYYNN 图 7、中序非递归遍历开始 申请一个StackElemType数组用一个临时变量存根的信息 数组标志致零 stop.ptr = p p=p-lchild top+判数组标志致是否为一输出结点的数据数组标位致一p = stop-1.ptr p= p-rchild结束NYYNNYYN判数组是否空判数组是否空判树是否空 图8、后序非递归遍历开始申请一个BiNode数组s申请两个整形变量数组首元赋为根结点s2*i+1 = root-lchild ;s2*i+2 = root-rchild i+root = si max=i输出数组结束N判断树是否空Y图9、层次序非递归遍历5.2、源程序我真诚地保证: 我自己独立地完成了整个程序从分析、设计到编码的全过程。 如果在上述过程中,我遇到了困难而求教于人,那么,我将在程序报告中详细地列举我所遇到的问题,以及别人给我的

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号