2013课程设计九宫格数独.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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

文档评论(0)

JFuOrhvGoo + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档