前言
学习数据结构的最终目的是解决实际的应用问题 特别是非数值计算类型的应用问题数据结构课程设计就是为此目的一次实际训练。 要求我们在对题目进行独立分析的基础上完成设计和开发并最终接受严格的测试考核。以深化对数据结构课程中基本概念、理论和方法的理解提升综合运用所学知识处理实际问题的能力使我们的的程序设计能力与调试水平有一个明显的提升。
课程设计所安排的题目都有一定的难度和深度从抽象数据类型的提炼、 数据结构选择到算法的设计均由我们每个人自主完成。在一周的时间内历经查找参考资料、使用技术手册、设计编码和撰写文档的实践进一步升华对软件工程师和程序员人格素质的认识和理解。
本课程设计的主要设计内容是 设计一个马踏棋盘问题的演示程序。
即将马随机地放在国际象棋的8*8棋盘的某个方格中然后令马按走棋规则开始进行移动。要求马将棋盘上的每个方格进入且只进入一次走遍全部64个方格。要求编制非递归程序求出马的行走路线将数字1 2,… 64依次填入一个8*8的方阵在屏幕上显示输出。
针对该问题本课程设计采用的是面向对象的开发语言J a va,在
Windows7,myecl ipse8.5.0的平台上开发出来并有图形界面。 最终较好的实现了全部要求达到了预期效果。从中我也学到了很多不仅仅是课堂外的新知识还有那种会查资料会学习新知识的能力。
这个课程设计的顺利完成离不开胡老师的指导和帮助在他的细心指导和帮助下我对马踏棋盘程序开发的整个流程有了深刻地了解和系统地掌握 在这里学生表示真诚地感谢。另外也谢谢这次课程设计提供给我帮助的同学们。 此外 本课程设计还参考了一些文献资料在此向这些文献资料的作者深表谢意。
本课程设计可作为数据结构和Java课程教学的参考案例。
由于时间仓促和本人水平所限设计中难免有不当和欠妥之处敬请老师不
吝批评指正。
笔者
2016.6
目录
摘要. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3-'
第一章需求分析. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4-
第二章概要设计. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5-
2.1系统描述。 。 。 。. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5
2.2运行环境. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .: :-
2.3马踏棋盘流程. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5
2.4算法设计
第三章详细设计
3.1 Jisuan类实现
3.2
3.3
3.4
Disizha ng
4.1
4.2
4.3
D iwu
5.1
5.2
Can kaowe nxia n
Fulu
摘要
本课程设计中的程序实现了马踏棋盘问题的求解 并能够演示起始位置在棋盘上任何位置的问题的实现•程序采用图形演示 使算法的描述更形象 更生动 使教学更能
产生良好的效果。对于该程序我严格按照面向对象的思想进行开发其中有Jsuan类,Shuchu类,Jframe类和Ma in四个类。其中Jsuan类主要是初始化各点的可走路径并且删除不合法的点 Shuchu类主要最优算法的实现 Jframe类为图形用户界面的设计 主要完成棋盘的绘制和结果的打印 Main类主要是负责整个程序的控制。最终调试运行通过实现了全部要求取得了理想效果。
关键词数据结构 马踏棋盘 J ava图形界面
Abstract
This course design of the program real ization horses on board the solution,and to dem on stratethe starti ng positi on on the board of the real izati on of the problem any positi on.The program usinggraphical prese ntati on, the method of more image, the more vivid description,and make the teachingmore can produce good effect.Forthe program, I in strict accorda nee with the object-orie nted ideas ofdevelopme nt, in clud ing Jisua n class,Shuchu class, Jframe classes and Main four classes.Amongthem Jisua n kind basical ly is the in itial points of walk path,and remove not legal point;Shuchu mainkinds of the real izati on of the optimal algorithm; Jframe class for the graphical user in terface desig n,the main finish drawing the board and results of the print;Main kinds of major is responsible for theentire process control . Final test and operation, real ize the requirements through al l ,make the idealeffect.
Key words:data structure horse on board Java graphical in terface
第一章需求分析
数据结构课程设计是计算机科学与技术专业学生必做的集中实践性环节之一是学习完《数据结构》课程后进行的一次全面的综合练习。其目的在于通过课程设计使学生能够得到较系统的技能训练从而巩固和加深对数据结构的基础理论知识的理解培养学生综合运用所学理论知识解决实际问题的能力使学生成为具有扎实的计算机理论基础和较强的独立动手能力的复合型、应用型人才。
马踏棋盘问题是一个古老而著名的问题 它最初是由大数学家Euler提出的.问题是这样的国际象棋中的棋子叫作马在一个空棋盘内移动 问它能否经过64格中的每一格且只经过一次 马按L行移动 即在某方向前进两格接着在与原方向垂直的方向上前进一格
本程序实现了马踏棋盘问题的求解并能够演示起始位置在棋盘上任何位置的问题的实现.程序采用图形演示 使算法的描述更形象 更生动 使教学更能产生良好的效果。
第二章概要设计
2.1系统描述
本程序采用myecl ipse8.5.0来编制整个程序 这样既可以使大家对算法的实现有了一定的了解也可以熟悉一下J ava图形界面以及J ava语言的命名规范。作为数据结构的课程设计本人希望同时也能让大家顺便熟悉一下 Java的基本语言结构和强大的开发能力。
在马踏棋盘的课程设计中我们严格按照面向对象的思想进行开发其中有Jisuan类Shuchu类 Jframe类和Main类。读者应注意各个类之间的关系 以便也能顺道理解Java中类的思想。
2.2运行环境
本程序是在windows7,myecl ipse8.5.0的环境下运行的。
2.3马踏棋盘流程
将马随机地放在国际象棋的8*8棋盘B o a rd[8][8]的某个方格中然后令马按走棋规则开始进行移动。要求马将棋盘上的每个方格进入且只进入一次 走遍全部64个方格。
2.4算法设计
2.4.1设计思想
①利用某种算法直接找到最优解算出最优路径而不是一步步尝试遇到错误回溯。
②设一数组与棋盘坐标-------对应1 1 到8 8 存放每个棋盘格上应算出的路径数字。
③路径从1〜64存放到与棋盘数组中对应的数组中将数组当形参传到图形用户界面利用Graphics绘制棋盘并打印数组。
④ 建立主函数调用计算路径类和绘制棋盘类。
2.4.2程序结构说明
程序的运行关系如图2-1.
图2-1程序运行关系图
2.4.3算法结构设计
①最优算法设计
准备阶段
(a)按国际象棋马的走法最多有8种可能创建数组intpath[][]={{0,0,0},{1,1,2},{2,1,-2},{3,-1,2},{4,-1,-2},{5,2,1},{6,2,-1},{7,-2,1},{8,-2,-1}}存放8中可能为了满足与棋盘--------------对应故用 3 X8数组。
(b)创建数组int [][]way=new int[9][9]存放棋盘每点可走的路径数。
(c)创建数组int [][]output=new int[9][9]存放最终绘制棋盘格中输出的数字 即行走路线。
(d)计算出棋盘上每点的可走路径数存入 way数组超出棋盘边界的点被舍弃让数组与棋盘--------对应。
计算阶段
(a)从用户输入起始点坐标存入m n。
(b)先假设每个点最小可走路径数为 min=8。
(c)根据way数组中已经存放的值与假设的最小可走路径数为8比较若小于8则存入min如此循环最多8次找出使min值最小的点设为下次要走的点依次类推直至找出64个点 即最优路径。
②用户输入
利用java提供的Scanner函数从操作台进行输入。
③图形用户界面
利用Jframe窗体建立图形用户界面编写构造函数用Graph ics()函数绘制矩形并填充颜色画出棋盘表格并利用drawStri ng()在相应的棋盘坐标中打印出output数组中数字。
第三章详细设计
3.1 Jisuan类实现publ ic classjisuan{ //计算棋盘中各点可走路径publ icvoid in it(i nt[][]way){int i ,j,k,x,y;in tpath[][]={{0,0,0},{1,1,2},{2,1,-2},{3,-1,2},{4,-1,-2},{5,2,1},{6,2,-1},{7,-2,1},{8,-2,-1}}; //存放马的行走规则 为了使坐标和棋盘一一对应定义8X3数组
fo r(i=1; i<=8; i++) //先初始各点可走路径为
fo r(j=1;j<=8;j++)way[i][j]=O;fo r(i=1; i<=8; i++) //计算各点可走路径如果合法便存储fo r(j=1;j<=8;j++)fo r(k=1;k<=8;k++)
{x=i ;y=j;x=x+path[k][1];y=y+path[k][2]; //x,y代表走下一步后的坐标通过k的增长改变行走的方向if(x>=1&&x<=8&&y>=1 //判断是否落在棋盘内否则不存储way[i][j]++ ; }
}//init
}//jisua n
注释
此类主要初始化各点的可走路径并且删除不合法的点
VoLLcloud LLC是一家成立于2020年12月互联网服务提供商企业,于2021年1月份投入云计算应用服务,为广大用户群体提供云服务平台,已经多个数据中心部署云计算中心,其中包括亚洲、美国、欧洲等地区,拥有自己的研发和技术服务团队。现七夕将至,VoLLcloud LLC 推出亚洲地区(香港)所有产品7折优惠,该产品为CMI线路,去程三网163,回程三网CMI线路,默认赠送 2G DDoS/C...
A2Hosting主机,A2Hosting怎么样?A2Hosting是UK2集团下属公司,成立于2003年的老牌国外主机商,产品包括虚拟主机、VPS和独立服务器等,数据中心提供包括美国、新加坡softlayer和荷兰三个地区机房。A2Hosting在国外是一家非常大非常有名气的终合型主机商,拥有几百万的客户,非常值得信赖,国外主机论坛对它家的虚拟主机评价非常不错,当前,A2Hosting主机庆祝1...
百纵科技:美国云服务器活动重磅来袭,洛杉矶C3机房 带金盾高防,会员后台可自助管理防火墙,添加黑白名单 CC策略开启低中高.CPU全系列E52680v3 DDR4内存 三星固态盘列阵。另有高防清洗!百纵科技官网:https://www.baizon.cn/联系QQ:3005827206美国洛杉矶 CN2 云服务器CPU内存带宽数据盘防御价格活动活动地址1核1G10M10G10G38/月续费同价点击...