基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx

上传人:b****5 文档编号:27659503 上传时间:2023-07-03 格式:DOCX 页数:68 大小:658.99KB
下载 相关 举报
基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx_第1页
第1页 / 共68页
基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx_第2页
第2页 / 共68页
基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx_第3页
第3页 / 共68页
基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx_第4页
第4页 / 共68页
基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx_第5页
第5页 / 共68页
点击查看更多>>
下载资源
资源描述

基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx

《基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx》由会员分享,可在线阅读,更多相关《基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx(68页珍藏版)》请在冰豆网上搜索。

基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文.docx

基于Web的JAVA五子棋对弈程序的设计与实现毕业设计论文

 

基于Web的JAVA五子棋对弈程序的设计与实现

摘要:

人工智能是一门正在迅速发展的新兴的,综合性很强的交叉科学。

它与生物工程、空间技术一起被并列为二十一世界三大尖端技术。

它的中心任务是研究如何使计算机去做那些过去只能靠人的智力才能做的工作。

目前各发达国家都把人工智能作为重点项目,列入本国的高科技发展计划当中,投入巨大的人力和物力。

计算机人机对弈也是其中之一。

作为人智能研究的一个重要分支,计算机博弈是检验人工水平的一个重要方面。

它的研究为人工智能带来了很多重要的方法和理论,产生了广泛的社会影响和学术影响。

五子棋人机对弈是计算机博弈中的一种。

研究其计算机算法,可以让我们看到人工智能的稚形,也有助于我们人脑的开发。

五子棋是我国发明的,研究它可以让更多的外国人了解五子棋,这有助于我国优秀文化的推广。

关键词:

人工智能;计算人机对弈;五子棋;JSP

JAVArenjuplaychessprogramdesignandimplementationBasedonWeb

ChongqingThreeGorgesUniversity,Wanzhou,Chongqing404000)

Abstract:

Artificialintelligenceisarapidlydevelopingnew,integratedastrongFrontierScience.Itiswithbio-engineering,spacetechnologyhasbeenlistedas21intheworldalongwiththethreecutting-edgetechnology.Itscentraltaskistostudyhowtomakethecomputerdothatinthepasttorelyonhumanintelligencetodo.AIiscurrentlyregardedasthefocusofthedevelopedcountriesincludedinthiscar'shigh-techdevelopmentprojectsinvestedtremendoushumanandmaterialresources.

Man-machinechesscomputerisoneofthem.Asahumanstudyofanimportantbranchofintelligence,thecomputergametotestthelevelofanimportantaspectofthemanual.Itsresearchinartificialintelligencehasresultedinmanyimportantmethodsandtheoriestoproduceawiderangeofsocialimpactandacademicimpact.

Man-machinechessgameRenjuinoneofthecomputer.Tostudythecomputeralgorithm,wecanseethebeginningofartificialintelligenceshadow,butalsohelpustohumanbraindevelopment.BackgammoninventedinChina,andtheresearchitcanallowmoreforeignerstounderstandandhelptopromoteChina'straditionalculture.

Keywords:

ArtificialIntelligence,Man-machineCchessComputer,Man-machineChess,Algorithm;JSP

1引言

电脑已经深入到日常工作和生活的方方面面,比如文字处理、信息管理、辅助设计、图形图像处理、教育培训以及游戏娱乐等。

Windows系统的推出使电脑从高雅的学术殿堂走入了寻常百姓家,各行各业的人们无须经过特别的训练就能够使用电脑完成许许多多复杂的工作。

然而,虽然现在世界上已经充满了花样繁多的各种软件,但它们依然不能满足用户的各种特殊需要,人们还不得不开发适合自己特殊需求的软件。

Java语言作为一种面向对象的编程语言,具有分布式,可移植,高性能,多线程等特点。

通过系统的学习,人们就可以使用它开发出功能齐全,满足特殊需求的应用程序。

Java语言易学易用,对学习者掌握技能,开拓思维都有很大的帮助。

我作为一名学生,在系统的学习了Java语言之后,经常用它搞一些小程序。

这次毕业设计,正好将学过的Java语言中的各种技术综合起来,用myeclipse开发工具编写一个小游戏,既对自己学过的技能进行一次检验,也能系统地将学过的知识复习巩固。

随着计算机技术的不断发展,网络技术的普及范围越来越广,网络能够提供的服务多样、便捷,已经成为人们生产生活中不可缺少的重要组成部分。

如今网络休闲游戏发展迅速,它凭借健康、方便、互动性强、益智等诸多优点,成为大部分现代人休闲娱乐的首选。

2五子棋对弈程序的可行性分析

可行性分析是通过对项目的主要内容和配套条件,如市场需求、资源供应、建设规模、工艺路线、设备选型、环境影响、资金筹措、盈利能力等,从技术、经济、工程等方面进行调查研究和分析比较,并对项目建成以后可能取得的财务、经济效益及社会环境影响进行预测,从而提出该项目是否值得投资和如何进行建设的咨询意见,为项目决策提供依据的一种综合性的系统分析方法。

2.1五子棋系统设计思路

五子棋系统基本设计思路是把系统按照实现模块进行分解,利用java进行编程。

2.2经济可行性分析

主要是对项目的经济效益进行评价,本系统开发费用对于学员在经济上是可以接受的,并且本系统实施后可以让用户很好的对五子棋进行更加深入的研究,有助于开发用户智力。

2.3技术上的可行性

技术上的可行性分析主要技术条件是否顺利完成开发工作,硬、软件是否满足开发者的需要等。

该系统采用的简单的二层结构,数据库选用MySQL,它相对于其他的数据库来说,安装简单,灵活性、安全性和易用性为数据库编程提供了良好的条件。

因此,系统的软件开发平台已成熟可行。

硬件方面,科技飞速发展的今天,硬件更新的速度越来越快,容量越来越大,可靠性越来越高,价格越来越低,棋硬件平台完全能满足此系统的需求。

2.4管理上的可行性

主要是管理人员是否支持,现有的管理制度和方法是否科学,规章制度是否齐全,原始数据是否正确等。

规章制度和管理方法为系统的建设提供了制度保障。

综上所述,此系统开发目标已明确,在技术和经济等方面都可行,并且投入少、见效快。

因此系统的开发是完全可行的。

3JAVA五子棋对弈现的需求分析

本系统主要根据根据老师提出的要求进行的需求分析:

3.1用户需求分析

根据老师提出的要求,我们把系统的用户分为两类:

普通用户、系统管理员用户,下面是我们对两种用户的需求进行的分析:

3.1.1普通用户主要需要:

根据分析,普通用户具有的功能:

(1)用户登录:

用户根据自己的密码登录本系统。

(2)棋局回放:

用户根据自己的需求回放自己以前下过的棋局。

(3)玩五子棋:

用户在点击playgame后会进入游戏界面玩游戏。

(4)悔棋功能:

在下棋过程中,用户根据自己的需求,选择悔棋。

(5)更改密码:

用户可以根据自己的需求更改自己的密码。

3.1.2系级管理员主要需要:

系统管理员是本系统的最高权限的管理员,他不仅具有普通用户的各种功能,还具有他独有的功能一下是系统管理员所具备的功能:

(1)用户登录:

用户根据自己的密码登录本系统。

(2)棋局回放:

用户根据自己的需求回放自己以前下过的棋局。

(3)玩五子棋:

用户在点击playgame后会进入游戏界面玩游戏。

(4)悔棋功能:

在下棋过程中,用户根据自己的需求,选择悔棋。

(5)更改密码:

用户可以根据自己的需求更改自己的密码。

(6)管理普通用户:

可以对普通用户进行添加和删除。

3.1.3系统用例图:

3.2数据字典的描述

数据字典是关于数据的信息的集合,也就是对数据流图包含的所有元素的定义的集合。

任何字典最重要的用途都是供人查阅对不了解的条目的解释,数据字典的作用也正是在软件分析和设计的过程中给人提供关于数据的描述信息。

在本系统中涉及到多种数据的存储,其中包括用户信息、用户每次玩游戏的信息、用户每盘棋的信息、用户每步棋的信息。

下面是给出的本系统的数据字典描述:

3.2.1用户信息表的数据字典的描述:

描述:

用与储存用户信息,其中有用户名,当用户登录后会在用户首页上显示。

用户密码用于登录本系统,用户权限是整数,1代表普通用户,既可以通过注册的用户;0代表系统用户,是系统自带的不可以通过注册获得。

3.2.2用户每次游戏信息表的数据字典描述:

3.2.3用户每盘棋信息表的数据字典描述:

3.2.4用户每步棋信息表的数据字典描述:

3.3五子棋对弈系统的数据流图

数据流图(DataFlowDiagram):

简称DFD,它从数据传递和加工角度,以图形方式来表达系统的逻辑功能、数据在系统内部的逻辑流向和逻辑变换过程,是结构化系统分析方法的主要表达工具及用于表示软件模型的一种图示方法。

下面简要介绍部分需求的数据流图:

3.3.1用户登录数据流图(DFD)

在用户登录过程当中,用户输入的信息经过加工处理后,通过对数据库的查询后返回给程序该用户的权限,数据流图(图3-1)如下:

3.3.2普通用户界面显示数据流图(DFD)

知道用户权限后,通过查询用户游戏信息,显示用户游戏信息。

数据流图(图3-2)如下:

3.3.3管理员用户界面显示数据流图(DFD)

知道用户权限后,通过查询用户游戏信息和所有普通用户信息,显示用户游戏信息。

数据流图(图3-3)如下

图3-3管理员用户数据显示数据流图

3.3.4用户棋局回放数据流图(DFD)

知道用户权限后,通过查询用户游戏信息和所有普通用户信息,显示用户游戏信息。

数据流图(图3-4)如下:

图3-4用户棋局回放数据流图

4JAVA五子棋对弈系统分析与设计

此系统为智力游戏,适合于各类游戏爱好者。

由于其经典性及其游戏的简单性,各类人士都可以也都爱玩。

人们在与电脑对战享受娱乐的同时,也会体会到自己的智力也会有所提升。

该款五子棋游戏功能虽然简单,但实现了人机,所以从这个角度来说,该款游戏需要电脑能准确的计算棋局。

虽然系统不大,但要在满足玩家的基本要求的情况下,电脑有一定的智能,能给于新手一定的帮助。

4.1系统设计总体思想、目标

本系统在结构设计中采用java的MVC模式,根据不同的功能划分不同的模块,该款五子棋游戏功能虽然简单,但实现了人机,所以从这个角度来说,该款游戏需要电脑能准确的计算棋局。

虽然系统不大,但要在满足玩家的基本要求的情况下,电脑有一定的智能,能给于新手一定的帮助。

4.2五子棋人机对弈系统的ER模型

经过对系统的分析,我们将系统划分出了用户信息、用户棋局信息、用户棋盘信息、用户下棋信息等几个实体,其各个实体的属性如下:

用户信息:

用户名、用户密码、用户权限

用户棋局信息:

用户名、棋局编号、棋局创建时间

用户棋盘信息:

棋局编号、X轴坐标、Y轴坐标、棋子状态

用户下棋信息:

棋局编号、用户X坐标、用户Y坐标、电脑X坐标、电脑Y坐标

本系统的具体ER模型如下:

图4-2用户棋局ER图

 

图4-3用户棋盘ER图

 

图4-4用户棋盘ER图

图3-1整体ER图

图4-5整体ER图

4.3JAVA五子棋对弈系统结构、功能设计

4.3.1系统结构设计

本系统主要针对用户提出的要求业务开发的系统,其结构设计情况如图(图4-6)所示:

图4-6系统结构图

4.3.2系统功能模块设计

该款游戏主要由一下几个模块组成(图4-7):

用户登录注册:

在玩五子棋之前,用户要先登录游戏,未注册的用户应该先注册,如果登录成功会跳到用户管理页面,登录信息错误会提示密码用户名错误。

人机对弈模式:

选择该模式可以实现人与电脑之间的对弈,电脑会智能的选择该在哪处下子,并会在每次下棋结束后判断是否有哪方已经获胜,如果获胜则结束本局游戏,并提示玩家游戏结束。

悔棋功能:

这个功能也是根据游戏的实际需求而存在的,在现实生活中难免有失误下错了棋,那么就需要悔棋。

此功能提供了悔棋功能,使得下棋的灵活性有所提高。

玩家若想悔棋,则只需选择悔棋按钮便可以重新下过刚才的棋,但只能悔一步棋。

棋局回放功能:

这个功能是更加用户需求设计的,该功能可以回放用户以前下过的棋局只要点击要回放的棋局,进入棋局回放页面,点击下一步就可以回放该棋局,点一下只能回放一步棋。

4.3.3设计思路

1.本程序要实现五子棋的游戏功能,必须先有一个棋盘,所以,通过html中的表格画的,棋盘是17*17,表格中是一个层,通过改变其背景图片来表示有无棋子,是白棋还是黑棋。

另外还有一个按钮:

悔棋按钮,用于提供悔棋功能,界面还显示系统时间,用户提示用户当前时间。

2.对于下棋的操作,通过对该层鼠标事件监听器onclick,每次当用户点击鼠标时,先取得点击的坐标值,然后换算成对应棋盘上(即棋盘数组)的位置(数组的下标)。

3.判断此处是否已经有棋子,如果有则用javascript提示玩家重新下子,否则通过ajax把点击的数组传递给后台,通过后台处理返回给前台数据来改变样式,在此处画上棋子。

4.判断该颜色棋子的上下左右是否满足连续五个,是的话提醒相应玩家获胜,不是的话,更换玩家下棋。

5.对于玩家的更换是程序自动的,每次用户点击鼠标后,若本局还未结束则会变换玩家,从而画出对应黑方白方的棋子,直到有一方获胜程序结束。

4.4程序设计分析

1.在网站的首页是登录界面,有登录和注册两个功能。

2.在登录成功会跳到用户信息页面,在该页面的右下角会列出该用户在最近5次,玩游戏的信息记录,点击该记录可以回放对应的棋局。

在信息下方有开始游戏和更改密码两个按钮。

3.绘制棋盘,17*17的方框,在方框处下棋子(实心黑白圆形)。

4.棋盘处于鼠标监听状态,当鼠标在棋盘上有点击操作的时候,程序会获得鼠标点击的坐标然后换算成对应的棋盘的位置,再判断此处是否有棋子,假如没有,那么在此处画出对应颜色的实心棋子,假如已经有棋子了,则提示玩家此处已经有棋子请重新下棋。

5.当用户点击表格中的层下完棋后,轮到电脑下子时,电脑会通过算法计算每个没有棋子的位置的重要性来选择最重要的位置下子。

6.当任何一方有五个棋子沿着横,竖,斜连在一起时,系统自动判断赢棋,并显示黑方或白方胜利。

棋局结束后,会返回用户信息页面。

7.程序流程如下图(图4-8):

4.5类的设计

1)由于要用到数据库,所以设计了一个用来连接数据库的类BaseDao,其中包括了两个方法和4个变量,类图(图4-9)如下:

2)下图是关于数据库中对应的表的类图(图4-10)关系:

3)虽然有了用户相关类,但是无法操作数据库中的用户信息,所以设计了操作用户表的类UserDishDaoImpl,该类继承BaseDao,并且实现IUserDao类,类图(图4-11)如下:

4)对于用户每次玩游戏的信息操作,用UserDishDaoImpl实现了各种操作。

类图(图4-12)如下:

5)对棋盘的各种信息保存操作,用类UserQipanDaoImpl来实现。

其中类图(图4-13)如下

6)对每局棋及每盘棋的各种保存操作,用UserStepDaoImpl来实现,其中类图(图4-14)如下:

7)由于程序是人机对弈,电脑下棋算法用Computer类来实现,其中有电脑下棋算法,还有电脑判断输赢算法,类图(图4-15)如下:

8)本程序的时序图(图4-16)如下:

4.6五子棋对弈系统的数据库设计

4.6.1系统用户表

名称

编码

数据类型

备注

用户名

userName

varchar(255)

用户输入,Notnull约束,是表的主键

用户密码

userPwd

varchar(255)

用户输入,Notnull约束

用户权限

userFlag

Int(11)

系统分配,Notnull约束,用于判断用户权限

4.6.2用户棋局表

名称

编码

数据类型

备注

棋局编号

dishId

Int(11)

系统自动分配,是该表的主键,Notnull约束

用户名

userName

varchar(255)

用户输入,Notnull约束

创建时间

playDate

Date

系统分配,Notnull约束

4.6.3用户棋盘表

名称

编码

数据类型

备注

棋局编号

dishId

Int(11)

系统自动分配,是改变的主键,Notnull约束

X轴坐标

X

Int(11)

是棋盘的X坐标,Notnull约束

Y轴坐标

Y

Int(11)

是棋盘的Y坐标,Notnull约束

状态

F

Int(11)

表示棋子状态,Notnull约束

4.6.4用户下棋信息表

名称

编码

数据类型

备注

下棋编号

stepId

Int(11)

系统自动分配,是改变的主键,Notnull约束

电脑X坐标

pcX

Int(11)

是电脑该步棋的X坐标,Notnull约束

电脑Y坐标

pcY

Int(11)

是电脑该步棋的Y坐标,Notnull约束

用户X坐标

psX

Int(11)

是电用户该步棋的X坐标,Notnull约束

用户Y坐标

psY

Int(11)

是电用户该步棋的X坐标,Notnull约束

棋局编号

dishId

Int(11)

是该表的外键,Notnull约束

5五子棋相关基础

5.1五子棋相关解释

引用《辞海》中所言,五子棋是“棋类游戏,棋具与围棋相同,两人对局,轮流下子,先将五子连成一行者为胜。

”。

五子棋的名称:

日文亦有“连五子、五子连、串珠、五目、五目碰、五格、五石、五法、五联、京棋”等多种称谓,英文则称之为FIR(FiveInARow的缩写)、Gomoku(日语“五目”的罗马拼音)、Gobang、connect5、mo-rphion。

捷克语piskvorky,韩语omok、韩国人还称之为情侣棋。

5.2五子棋相关规则

1.五子棋行棋时,黑棋先下第一子,由天元开始,后白棋在黑棋周围的方框的落子。

接着黑方再以天元中心的25个交叉点的范围内落盘面的第三子,之后黑白双方相互顺序子。

2.最先在棋盘上横向,纵向,斜向形成已方的五个棋子连续的一方为胜。

3.出现禁手对方指出后将判负,其中包括两个或两个以上的活三,活四,长连均称之为禁手。

4.禁手只对黑棋有效,白棋无禁手。

5.黑方禁手形成时,白方需立即指出,黑方将被判负。

若白方未发现黑方禁手存在而继续应子,其后指出黑方禁手不能判黑方负。

6.黑方连五与禁手同时形成,因黑方已连成五即黑方已获胜,故禁手规则失效。

7.在对局中,在盘上落下的子又拿起来,此动作称为拔子,若拔子将被判为负。

8.在对局中棋子掉落在棋盘上将被判负。

若推子或蹭子,以盘面第一落点为准。

用手将棋子推正不算违犯规则。

9.在对局中,一方自行中止比赛如:

中途退场,将被判负。

10.在对局中对方宣布认输,本局获胜。

11.超过比赛规定所用时间限制,将被判为负:

正式比赛期间,迟到时间超过比赛容许时间将被判负。

12.如下至最终一子仍不分胜负则定为平局。

13.中盘期间双方同意和局提议,判定为平局。

5.3五子棋常用术语

1.着:

也称“步”。

对局中把一个棋子按照规则放到某一点,称之为一着棋。

一着是否完成有两种规则:

  1)在执行落子无悔规则是,以行棋者的手离开棋子为一着已完成。

  2)在执行限时规则时,以行棋者按下棋钟作为一着已完成。

2.PASS:

五子棋中引入的英文名称,即应该行棋的一方主动放弃此次行棋的机会,由对方继续行棋。

3.先手:

对方必须应答的着法,如对方形成活三必须阻止其形成活四。

4.绝对先手:

相对先手而言,即形成同色连四或嵌五,对方必须应着,就是绝对先手。

绝对先手又叫“冲”。

5.VCF:

(VictoryofContinusFour的缩写)意思是利用连续冲四取胜之意。

利用连续不断的冲四或嵌五的绝对先手,制止形成连五获得胜利的一种方法。

在对局接近尾声或排局解题中一种常见的取胜技巧。

6.追下取胜:

是指白棋利用黑棋禁手取胜的战术。

白1冲四,迫使黑2形成“四、四”禁手(即冲四,活四禁手),这种取胜方法叫做追下取胜。

7.自由取胜:

追下取胜以外的取胜方法,即未利用黑棋禁手战术而取胜。

8.一子双杀:

是指对局中一方落子后出现两个叫杀点即两个获胜点,而使对方无法防守的情形。

一般是有两个冲四活三点,白棋的双活三,双四均可称为一子双杀。

9.阳线:

棋盘上可见的横线与直线的总称。

10.阴线:

也称“斜线”。

是棋盘上不可见的斜行线。

11.“四、三”:

指同时具备两个先手,其中一个四,另一个是活三。

12.“活三”、“嵌五”、“冲四”:

参见五子棋重要棋形讲座。

13.禁手:

对局中禁止使用的战术或被判为负的行棋手段。

14.开局:

也称“布局”。

布局阶段大体为七至十几着之内。

种类繁多,职业连珠五子棋有二十四种开局。

   

15.局面:

亦称“局势”。

为对局中某一段时间内双方子力的配置情况。

16.优势:

是指足以取胜的优势局面,其对方即为败势。

17.妙着:

对局中走出的一步精妙的着法。

既合乎逻辑又出人意料,有使局面顿时改观的效果,对局势的发展及对局的质量都有重大影响。

18.好着:

也称“佳着”。

对局中成功的某一步。

19.正着:

对局的某一局面中的正确着法。

20.劣着:

对局中,导致严重不利后果的一步错误着法。

21.败着:

也称“失着”“漏着”。

对局中造成局面恶化的一步严重错误着法。

22.等着:

对局中具有等待性的一步着法,主要意图是等待有利时机。

23.废着:

也称“空着”。

对局中不起作用的着法。

实际上指浪费时间毫无疑义的错着。

24.抢先:

对局中利用反活三或冲四的强制手段夺取主动权的着法。

25.打谱:

按照棋谱演练着法,是提高棋艺水平的重要方法之一。

26.复局:

也叫“复着”。

对局结束又重演对局的过程。

一般用以研究、比较双方的成败得失和着法的优劣。

6系统平台、计算模式及技术

1)系统的硬件平台:

一台台式计算机

2)系统的软件平台:

Windowsxp/windows7IE浏览器等

6.1计算模式的进化及本系统选用的模式优越性

回顾计算机的发展史,计算模式有过三次质的飞跃:

6.1.1集中式管

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试认证 > 从业资格考试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1