- 1、本文档共26页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构课程设计马踏棋盘求全部解及演示程序
安徽工程大学 信息10 课程设计
马踏棋盘的求解及演示设计
摘 要
数据结构是计算机科学与技术专业的一门核心专业基础课程,是一门理论性强、思维抽象、难度较大的课程。我认为学习数据结构的最终目的是为了获得求解问题的能力。对于现实世界中的问题,我们应该能从中抽象出一个适当的数学模型,该数学模型在计算机内部用相应的数据结构来表示,然后设计一个解此数学模型的算法,再进行编程调试,最后获得问题的解答。《数据结构》课程设计是计算机科学技术专业集中实践性环节之一,是学习完《数据结构》课程后进行的一次全面的综合练习。开设本课程设计实践的主要目的就是要达到理论与实际应用相结合,提高学生的动手能力,完成计算机应用能力的培养;本课程设计主要解决马踏棋盘的问题,找出踏遍棋盘的多种路径,并实现动态要是过程。
马踏棋盘问题,实际上是图论中的哈密顿通路问题,是 典 型 的NP问 题,求解的问题与算法设计有很大关系,如果采取穷举有哪些信誉好的足球投注网站的话,很容易陷入海量有哪些信誉好的足球投注网站的状态,耗费巨大的时间,使问题几乎不可解,因此马在棋盘上遍历采用算法当中的深度优先算法和启发式贪心算法,用栈来存储遍历过程,通过对栈的使用实现对所有路径的有哪些信誉好的足球投注网站。在调试过程发现,启发式贪心算法,针对于马踏棋盘问题有着极大的好处,就是无论从棋盘上哪个点开始,找到一条遍历完棋盘的通路是不需要回溯的,也就节省了大量的时间,而试探性的操作对于每个点都也只有168步,所以求出所有路径在 不到一秒的时间内完成。
关键词:马踏棋盘;骑士周游;哈密顿通路;NP-完全问题;贪心算法;回溯法;
目 录
马踏棋盘的求解及演示设计 1
目 录 2
第一章 引 言 3
第二章 需求分析 3
2.1问题描述 3
2.2基本要求 3
2.3具体需求 4
2.4开发环境 4
第三章 概要设计 4
3.1 系统概述 4
3.2 系统描述 5
3.3逻辑设计 5
第四章 详细设计 6
4.1 功能模块设计 6
4.2 数据结构设计 6
4.3算法设计 8
第五章 调试与分析 12
5.1 调试分析 12
第六章 系统试用说明 13
6.1 系统试用说明 13
第七章 总结与体会 13
参考文献 14
第一章 引 言
本课程设计主要研究马踏棋盘的问题,即骑士周游问题,是将马随机放在国际象棋的8×8棋盘的某个方格中,“马”按照走棋规则进行移动,要求每个方格只进入一次,走遍棋盘上全部64个方格。许多知名的数学家,如德莫弗(De Moivre)、欧拉(Euler)与范德蒙德(Vandermonde)等人,在过去的200年中都研究过这个问题,
(2)界面友好,函数功能要划分好
(3)要有算法设计的流程图
(4)程序要加必要的注释
(5)要提供程序测试方案
2.3具体需求
1、首先要找到马踏棋盘棋盘的多条路径。
2、实现马踏棋盘的动态演示过程。
3、优化算法,提高算法效率,以递归与非递归的方式实现
2.4开发环境
开发环境:Windows 8
辅助工具:Visual Studio 2012 ,MyEclipse 10.5
运行环境:Windows XP/Vista/7/8
第三章 概要设计
3.1 系统概述
3.11 系统流程图
3.12 主函数main()的执行流程
求解多条路径子系统: 自动演示路径子系统
N
Y
N
Y
3.2 系统描述
通过VS2012完成的寻找多条路径的子系统,通过java来实现马踏棋盘的动态演示子系统。在寻找多条路径的子系统中,通过启发式贪心算法,将某点的下一步最少通往其它落脚点,将该点确定为最佳落点。每次只走下一步通向其他点最少的点。用栈记录探寻的过程,将走过的点标记为1,试探而没有走的点标记为0.最后通过寻找出栈标志为0的点来寻找其他路径。在动态显示模块式通过java的线程机制是先的自动动画演示。
3.3逻辑设计
抽象数据类型
棋盘上某点的位置坐标结构体Postion
把个方向试探的增量位置数组direct[8]
棋盘某点通向其他点的可到达数的二位数组access[8][8]
链栈
用来记录可到达下一
文档评论(0)