- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
中南民族大学管理学院
学生课程设计报告课题名称:java课程设计选题名称:九宫格数独年 级:2009专 业: 信息管理与信息系统
学 号:0姓 名:指导教师:完成地点: 管理学院综合实验室
完成日期: 2011年9月25日2011学年至2012学年度第一学期目 录
题目描述3
问题分析3
问题分解4
系统设计6
系统实现11
系统设计和软件发布24
难点及关键技术分析31
心得体会32
一、题目(问题)描述
在9×9格的大九宫格中有9个3×3格的小九宫格,并提供一定数量的数字。根据这些数字,利用逻辑和推理,在其它的空格上填入1到9的数字。每个数字在每个小九宫格内只能出现一次,每个数字在每行、每列也只能出现一次。 这种游戏只需要逻辑思维能力,与数字运算无关。虽然玩法简单,但数字排列方式却千变万化,所以不少教育者认为数独是锻炼脑筋的好方法。
二、问题分析
1、基本解法:利用1 ~ 9 的数字在每一行、每一列、每一宫都只能出现一次的规则进行解题的方法。单元格:数独中最小的单元,标准数独中共有81个; 行:横向9个单元格的集合; 列:纵向9个单元格的集合; 宫:粗黑线划分的区域,标准数独中为3×3的9个单元格的集合; 已知数:数独初始盘面给出的数字; 候选数:每个空单元格中可以填入的数字。
String类的对象:atext[i][j]属于JtextField类的对象:text[i][j]、
属于JPanel类的对象:apanel[ ]、panel[ ]
类:包括上述所有类及父类Jframe。
2、确定类的属性。
ShuDu1: publicString: public
JtextField:privateJPanel:private
Jframe:public
3、确定对象之间的关系,包括依赖、泛化、关联、实现等等。
Jframe与主类ShuDu1之间:泛化
texts[ ](JtextField)与atext [ ](String)之间:依赖
String与ShuDu1之间:依赖
Resizable、Editable、Visible与texts[ ]之间:实现
i、j与text[i][j]、atext[i][j]之间:关联
类设计 类名 角色 变量(属性) 行为 ShuDu1 表示一个数独 MenuaBar:添加菜单项, setSize():设置尺寸等
add():添加文本及组件
setMenuBar():设置难易等级菜单 ShuDuAns 设置答案窗口 setSize():设置尺寸等
JPanel( ):设置面板布局 Public void actionPerformed(ActionEvent e) 单击事件处理方法 单击实践 JOptionPaneshowMessageDialog():弹出提示信息框 接口名 属性 ActionListener add ActionListener():注册单击事件监听器 ItemListener四、系统设计(类设计、数据设计、方法设计、算法设计等)
类的设计(对象的设计)(类图、对象图)
程序流程图java 程序中数独的算法设计
static int DFS(){for(int i=1;i=9;i++){for(int j=1;j=9;j++){if(data[i][j]==0){for(int k=1;k=9;k++){if( row[i][k]==0 col[j][k]==0 sql[(i+2)/3][(j+2)/3][k]==0 ){data[i][j]=k;row[i][k]=1;col[j][k]=1;sql[(i+2)/3][(j+2)/3][k]=1;if( DFS()==1 )return 1;else{data[i][j]=0;row[i][k]=0;col[j][k]=0;sql[(i+2)/3][(j+2)/3][k]=0;}}if(k==9)return 0;}}}}return 1;}static void set_data_zero(){ //数独的初始化
for(int i=0;i=9;i++){for(int j=0;j=9;j++){data[i][j]=0;}}}static void setnum(){ //数独数字的设置
setzero();set_data_zero();for(int i=1;i=9;i++){ //尝试填充的次数int n =(int)(Math.random()*100)+1; //添加任意整数int j=i*3-((i+2)/3*8-6);data[i][j]=n%9+1; //产生数字 int k=d
您可能关注的文档
最近下载
- 第十章正交试验设计.ppt VIP
- 鲁拜集(黄克孙郭沫若对照).pdf VIP
- (2025秋新版)青岛版三年级科学上册《5 .制作动物分类图册》PPT课件.pptx VIP
- 2025年(精品)成都七中学校自主招生考试试题 .pdf VIP
- 小学二年级新学期家长会班主任发言稿.docx VIP
- 现浇箱梁专项施工方案.doc VIP
- 北师大版数学二年级下册 长方形与正方形.ppt VIP
- QFSN-600-2型发电机铁心损坏分析 Analysis on Damage of QFSN-600-2 Generator Core.pdf VIP
- 小学二年级新学期家长会班主任发言稿.pdf VIP
- 小箱梁吊装履带吊安拆方案.docx VIP
文档评论(0)