《基于vc++的五子棋程序设计与实现大学论文.doc》由会员分享,可在线阅读,更多相关《基于vc++的五子棋程序设计与实现大学论文.doc(24页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、河北农业大学现代科技学院毕业论文(设计)题 目:基于VC+的五子棋程序设计与实现摘 要C+语言是一种面向对象的语言,尽管在当前,可视化语言发展迅速,普及很快,但C+语言作为一种基础的语言,它的有时依然存在,甚至有时它是不可替代的,特别是和硬件接口技术相联系的软件。五子棋游戏是一种简单大众的游戏,自计算机实现以来,深受广大电脑玩家的喜爱,现在流行的五子棋游戏软件大多缺乏美观的界面,和容易的操作方法,电脑的AI值也不是很高。本文通过C+语言在计算机图形方面的编程,设计了五子棋游戏软件,使该软件具有还算美观和操作简单的界面,在人机对战时,分为低级,中级和专家级,加大对游戏的乐趣,当然也可以实行人人对
2、战。本游戏是以C+语言作为开发工具,采用搜索算法设计最优落子点开发的游戏软件。本文就是介绍五子棋软件设计的全过程。关键字 C+语言 面向对象 最优落子AbstractC + + language is an object-oriented language, although in the current, visual language developed rapidly, spread quickly, but the C + + language as a basic language, it is sometimes still exists, and sometimes it is
3、irreplaceable, especially with hardware interface technology associated software. Volkswagen backgammon game is a simple game, since the computer to realize, the majority of PC gamers love, now popular backgammon game software lacks most beautiful interface, and easy method of operation, AI value of
4、 the computer is not very high. In this paper, C + + programming language in computer graphics, design a backgammon game software, so that the software has the appearance and operation is fairly simple interface, the man-machine war, divided into low, intermediate and expert level, increase the game
5、 fun, of course, can also be implemented for all war. This game is based on C + + language as a development tool, the search algorithm design optimal point developed game software. This article is to introduce the whole process of backgammon software design.Keyword C+ language Object-oriented the op
6、timalinitial目录1绪论61.1五子棋的简介61.2 Visual C+的介绍71.3 开发环境及运行环境71.3.1 开发环境71.3.2 运行环境72 系统分析82.1系统调研82.2可行性分析82.3技术可行性分析93软件架构103.1 棋盘类103.1.1主要成员变量103.2 主要成员函数说明103.2.1 清空棋盘103.2.2 绘制棋子103.2.3 左键消息113.2.4 绘制棋盘113.2.5 对方落子完毕113.2.6 胜负的判断113.3 游戏模式类113.3.1主要成员变量113.3.2主要成员函数123.4 资源编辑133.5消息说明153.5.1落子消息1
7、53.5.2声音消息153.5.3提示消息153.5.4悔棋消息153.5.5输赢消息153.5.6再次开局消息164主要算法174.1判断胜负174.2人机对弈算法174.2.1获胜组合184.2.2落子后处理184.2.3查找棋盘空位184.2.4落子打分184.2.5防守策略184.2.6选取最佳落子195 软件实现195.1游戏运行196补充说明237结论24致谢241绪论1.1五子棋的简介五子棋是起源于中国古代的传统黑白棋种之一。现代五子棋日文称之为“連珠”,英译为“Renju”,英文称之为“Gobang”或“FIR”(Five in a Row的缩写),亦有“连五子”、“五子连”、
8、“串珠”、“五目”、“五目碰”、“五格”等多种称谓。 五子棋不仅能增强思维能力,提高智力,而且富含哲理,有助于修身养性。五子棋既有现代休闲的明显特征“短、平、快”,又有古典哲学的高深学问“阴阳易理”;它既有简单易学的特性,为人民群众所喜闻乐见,又有深奥的技巧和高水平的国际性比赛;它的棋文化源渊流长,具有东方的神秘和西方的直观;既有“场”的概念,亦有“点”的连接。它是中西文化的交流点,是古今哲理的结晶。五子棋的娱乐性强、规则简单、易学、流行性广,普通人不需长时间专门训练即可自如行棋,因此极受大众喜欢。五子棋规则为: 第一:五子棋行棋时,黑棋先下第一子,由天元开始,后白棋在黑棋周围的交叉点的落子。
9、接着黑方再以天元中心的25个交叉点的范围内落盘面的第三子,之后黑白双方相互顺序子。第二:最先在棋盘线交点横向,纵向,斜向形成已方的五个棋子连续的一方为胜。第三:出现禁手对方指出后将判负,其中包括两个或两个以上的活三,活四,长连均称之为禁手。 第四:禁手只对黑棋有效,白棋无禁手。第五:黑方禁手形成时,白方需立即指出,黑方将被判负。若白方未发现黑方禁手存在而继续应子,其后指出黑方禁手不能判黑方负。第六:黑方连五与禁手同时形成,因黑方已连成五即黑方已获胜,故禁手规则失效。 第七:在对局中,在盘上落下的子又拿起来,此动作称为拔子,若拔子将被判为负。第八:在对局中棋子掉落在棋盘上将被判负。若推子或蹭子,
10、以盘面第一落点为准。用手将棋子推正不算违犯规则。第九:在对局中,一方自行中止比赛如:中途退场,将被判负。第十:在对局中对方宣布认输,本局获胜。第十一:超过比赛规定所用时间限制,将被判为负:正式比赛期间,迟到时间超过比赛容许时间将被判负。 第十二:如下至最终一子仍不分胜负则定为平局。第十三:中盘期间双方 同意和局提议,判定为平局。1.2 Visual C+的介绍Visual C+ 6.0,简称VC或者VC6.0,是微软推出的一款C+编译器,将“高级语言”翻译为“机器语言(低级语言)”的程序。Visual C+是一个功能强大的可视化软件开发工 具。自1993年Microsoft公司推出Visual
11、 C+1.0后,随着其新版本的不断问世,Visual C+已成为专业程序员进行软件开发的首选工具。虽然微软公司推出了 Visual C+.NET(Visual C+7.0),但它的应用有很大的局限性,只适用于Windows 2000、Windows XP和Windows NT4.0。所以实际中,更多的是以Visual C+6.0为平台。Visual C+6.0由Microsoft开发, 它不仅是一个C+ 编译器,而且是一个基于Windows操作系统的可视化集成开发环境(integrated development environment,IDE)。Visual C+6.0由许多组件组成,包括编
12、辑器、调试器以及程序向导AppWizard、类向导Class Wizard等开发工具。 这些组件通过一个名为Developer Studio的组件集成为和谐的开发环境。Microsoft的主力软件产品。Visual C+是一个功能强大的可视化软件开发工具。自1993年Microsoft公司推出Visual C+1.0后,随着其新版本的不断问世,Visual C+已成为专业程序员进行软件开发的首选工具。虽然微软公司推出了Visual C+.NET(Visual C+7.0),但它的应用的很大的局限性,只适用于Windows 2000,Windows XP和Windows NT4.0。所以实际中,
13、更多的是以Visual C+6.0为平台。Visual C+6.0以拥有“语法高亮”,自动编译功能以及高级除错功能而著称。比如,它允许用户进行远程调试,单步执行等。还有允许用户在调试期间重新编译被修改的代码,而不必重新启动正在调试的程序。其编译及创建预编译头文件(stdafx.h)、最小重建功能及累加连结(link)著称。这些特征明显缩短程序编辑、编译及连结的时间花费,在大型软件计划上尤其显著。1.3 开发环境及运行环境 1.3.1 开发环境Intel Pentium 4 2.0GHz,512M内存,80G硬盘;Microsoft Windows 2000 Professional;Micro
14、soft Visual C+ 6.0;Microsoft Developer Network for Visual Studio.NET 98; Visual Assist X 10.1.1301.0 1.3.2 运行环境 Intel Pentium 2及以上处理器,32M以上内存,4G以上硬盘;Microsoft Windows 9X/NT操作系统; 800*600或以上的屏幕分辨率2 系统分析2.1系统调研正式开发五子棋游戏之前进行调研是非常必要的,其必要性主要表现在以下几个方面。(1)明确用户的要求,以根据调查结果进行可行性分析,确认系统的开发是否可行。(2)提出新系统的人员并不都是系统
15、研究人员,有些人对于其功能和处理数据的方法没有明确的认识。它们只是根据自己业务工作的需要提出了要求,系统开发人员要对此进行详细的调查和分析,确认用户的要求可以通过现有的计算机技术实现,保证开发的管理信息系统的功能与用户提出的要求相吻合。总之,必要对现行系统进行详细的调查,明确用户需求,保证开发的新系统的功能与用户的要求相吻合,避免耗费大量的人力、物力、财力,新系统的开发却失败的悲剧发生。2.2可行性分析可行性分析是在用户的要求和系统调研的基础上进行的,对新系统的开发从社会、技术、经济、管理等方面进行分析,并得出新系统的开发工作可行、不可行、需要修改、追加投资、暂缓开发、分步实施等方案和结论,最
16、后完成可行性分析。可行性分析一般可定义为:可行性分析是在建设的前期对工程项目的一种考察和鉴定,对拟议中的项目进行全面与综合的技术、经济能力的调查,判断它是否可行。可行性分析阶段的主要工作包括以下几个方面: (1)新系统目标可行性分析:分析新系统的目标是否符合企业的现状和发展的需要。 (2)社会可行性分析:社会可行性分析主要是指管理信息系统的开发是否符合国家法律政策,是否,能够与社会大系统实现良好的对接。 (3)技术可行性分析:技术可行性分析是根据新系统的目标来衡量是否具备所需要的技术,包括系统开发人员数量和水平,硬件方面,软件方面及其它应用技术。 (4)经济可行性分析经济可行性分析主要是对开发
17、新系统所投入的资金与系统投入使用后所带来的经济效益进行比较,确认新系统是否会给企业带来一定的经济效益。 (5)管理可行性分析:管理可行性分析主要是分析企业现行的管理体制和企业领导是否具有现代化的管理意识和管理水平。2.3技术可行性分析 技术可行性分析主要包括四个方面:目前有关的技术能否支持所开发的新系统;新系统开发人员的数量和水平,即人力资源;硬件和软件资源。 (1)技术支持:首先根据新系统的目标,考虑目前有关的技术能否支持所开发的新系统。这里讨论的技术必须是已经普遍使用的,而不是待研究的或正在研究的。对于本系统,本人是采用C+编写的。而在开发五子棋的过程运用到了,图形的绘制(主要是对棋子的绘
18、制,棋盘的绘制的)。还有C+种对声音的播放方式(主要是用于下棋的时候的落子声音,悔棋时的声音,赢棋时的声音,输棋的声音)。文件的保存和载入(主要用于对棋盘信息的储存和打开)。 (2)硬件资源:开发管理信息系统所需的硬件资源包含以下两个方面:系统开发人员在管理信息系统的开发过程中所需要的计算机设备及其有关的外部设备;管理信息系统开发成功投入使用后,使用单位所应具备的计算机设备及其有关的外围设备。对硬件资源进行可行性分析时主要考虑计算机的主机内存、类型、功能、联网能力、安全保护措施以及输入/输出设备,外存储器和联网数据通信设备的配置、功能、效率等指标是否符合系统方案设计要求,同时还要考虑计算机的性
19、能/价格比。本系统对计算机的要求不高,一般的硬件配置都能运行此系统。3软件架构3.1 棋盘类整个架构的核心部分。封装了棋盘的各种可能用到的功能,如初始化、判断胜负等。用户操作主界面,主界面与棋盘类进行交互来完成对游戏的操作。3.1.1主要成员变量 (1)棋盘等待由于在玩家落子后需要等待对方落子,例如:黑子先下,白字就处于等待状态,这时白子是不能落子的。还有就是悔棋,直接发出悔棋信息就能悔棋了。 (2)棋盘数据这是一个15*15的二位数组,用来保存当前棋盘的落子数据。其中对于每个成员来说,0表示落黑子,1表示落白子,-1表示无子。 (3)游戏模式指针这个游戏类的对象指针是可行类的核心内容。它所指
20、向的对象实体决定了可行在执行一件事情时候的不同行为,具体的内容请参见“游戏模式”一节。 (4)网络连接用来表示当前网络连接的情况,在网络对弈游戏模式下客户端连接服务器的时候用来判断是否连接成功;事实上,它也是区分当前游戏模式的唯一标志。3.2 主要成员函数说明3.2.1 清空棋盘在每一局游戏开始的时候都需要调用这个函数将棋盘清空,也就是棋盘的初始化工作。在这个函数中,主要发生了这么几件事情: (1)将数据中的每一个落子位置为无子状态(-1)。 (2)按照传入的参数设置棋盘等待标志wait,以供先、后手的不同情况之用。 (3)使用delete将came的指针所指向的原有游戏模式对象从堆上删除。3
21、.2.2 绘制棋子这无疑是很重要的一个函数,它根据参数给定的坐标和颜色绘制棋子。绘制的详细过程如下: (1)将给定的棋盘坐标换算为绘图的像素坐标。 (2)根据坐标绘制棋子位图。 (3)如果先前曾下过棋子,则将上一个绘制棋子上的最后落子指示矩形擦除。 (4)在刚绘制完成的棋子四周绘制最后落子指示矩形。3.2.3 左键消息作为棋盘唯一响应的左键消息,也需要做工作: (1)如果棋盘等待标志wait为true,则直接发出警告声音并返回,即禁止落子。 (2)如果点击时的鼠标坐标在合法坐标(0,0)(14,14)之外,亦禁止落子。 (3)如果走的步数大于1步,方才允许悔棋。 (4)进行胜利判断,如胜利则修
22、改UI状态并增加胜利数的统计。 (5)如未胜利,则向对方发送已经落子的消息。 (6)落子完毕,将Wait标志置为TRUE,开始等待对方回应。3.2.4 绘制棋盘每当图像消息触发时,都需要对棋盘进行重绘。在图像上作为响应绘制消息的消息处理函数使用了双缓冲技术,减少了多次绘图可能导致的图像闪烁问题。这个函数主要完成了以下工作: (1)装载棋盘位图并进行绘制。 (2)根据棋盘数据绘制棋子。 (3)绘制最后落子指示矩形。3.2.5 对方落子完毕在对方落子之后,仍然需要做一些判断工作,这些工作与左键消息中的类似,在此不再赘述。3.2.6 胜负的判断这是游戏中一个极其重要的算法,用来判断当前棋盘的形势是哪
23、一方获胜。3.3 游戏模式类这个类负责对游戏模式进行管理,以及在不同的游戏模式下对不同的用户行为进行不同的响应。由于并不需要CGame本身进行响应,所以将其设计为了一个纯虚类。3.3.1主要成员变量(1)棋盘指针由于在游戏中需要对棋盘以及棋盘的父窗口主对话框进行操作及UI状态设置,故为CGame类设置了这个成员。 (2)落子步骤一个好的棋类程序必须要考虑到的功能就是它的悔棋功能,所以需要为游戏类设置一个落子步骤的列表。由于人机对弈和网络对弈中都需要这个功能,故将这个成员直接设置到基类CGame中。3.3.2主要成员函数 (1)悔棋操作在不同的游戏模式下,悔棋的行为是不一样的。人机对弈模式下,计
24、算机是完全允许玩家悔棋的,但是出于对程序负荷的考虑,只允许玩家悔棋当前的两步棋(计算机一步,玩家一步)。双人对弈模式下,悔棋的过程为:首先由玩家向对方说出悔棋请求(悔棋消息),然后由对方决定是否允许玩家悔棋,在玩家得到对方的响应消息(允许或者拒绝)之后,才进行悔棋与否的操作。(2)初始化操作对于不同的游戏模式而言,也就有不同的初始化方式。对于人机对弈模式而言,初始化操作包括以下几个步骤:设置主界面计算机玩家的姓名;初始化所有的获胜组合;如果是计算机先走,则占据天元(棋盘正中央)的位置。(3) 发送落子消息 在玩家落子结束后,要向对方发送自己落子的消息。对于不同的游戏模式,发送的目标也不同:对于
25、人机对弈游戏模式,将直接把落子的信息(坐标、颜色)发送给相应的计算函数; 对于双人对弈游戏模式,将把落子消息发送给套接字,并由套接字转发给对方。 (4)胜利后的处理 这个成员函数主要针对双人对弈模式。在玩家赢得棋局后,这个函数仍然会调用将玩家所下的制胜落子步骤发送给对方玩家,然后由游戏端来判定自己失败。3.4 资源编辑由于我们这个程序出现的关于资源编辑的内容太多,我们具体介绍如下: 见下图3-1和图3-2,我们需要添加的有:图3-1 黑子图3-2 白子说明:由于下棋时我们必须把鼠标热点设置在中间,点击下图(图3-3)最右边按扭,然后把鼠标移动到图像中你想设置为热点的地方,按下鼠标左键。图 3-
26、3 热点说明:由于我们的图标支持256色,按下下图(图3-4)最右边按扭,选择Device里面显示的选项。图3-4 黑子像素说明: 工具栏一般都是根据菜单选项而产生的,它的ID一般都能从菜单的ID中找到。3.5消息说明网络间传递的消息,都遵循以下一个结构体的形式:(1) 我们这用SY来表示消息的id。(2) 纵轴用x,横轴用y,x、y表示落子的坐标。(3) Color表示落子的颜色。(4) SSY随着SY的不同而不同。3.5.1落子消息表明对方落下了一个棋子,其中x、y和color成员有效SSY成员无效。在人机对弈游戏模式下,亦会模拟发送此消息以达到程序模块一般化的效果。3.5.2声音消息你可
27、以选着你想要的,有声或者无声。建议有声,因为有声音将会提示,如果你快输时,会发出一个响声的。而且有声音更加的增加了游戏的乐趣。3.5.3提示消息当你想不到你下一步下那个位置的时候,你可以选择提示选项,它将会为你提示出下一步该如何去落子。3.5.4悔棋消息 表示你想悔棋,那么你就直接发出消息,直接悔棋一步,而不能悔棋两步,还有就是,重新下了第二步后,可以重新悔棋,不过还是只能悔棋一步。3.5.5输赢消息你赢了,就是显示你赢,而你输,就显示你输了。其中,还有你共下了多少步而输或赢了对手,反之一样。当然也提供了,悔棋多少步的信息出来。还有你的评语消息。3.5.6再次开局消息 表示你想再开一局,那你就
28、直接发出消息,然后再开一局。当然,你可以选着人机对战或者双人对战。当你选着人机对战时,你还可以选着你想要的机器的智能,你选着的级别越高,智能也就越高。4主要算法五子棋游戏中,有相当的篇幅是算法的部分。无论是人机对弈,还是网络对弈,都需要合理算法的支持,本节中将详细介绍五子棋中使用的算法。4.1判断胜负五子棋的胜负,在于判断棋盘上是否有一个点,从这个点开始的右、下、右下、左下四个方向是否有连续的五个同色棋子出现,如图4-1所示。图4-1判断胜负方向这个算法也就是CTable的Win成员函数。从设计的思想上,需要它接受一个棋子颜色的参数,然后返回一个布尔值,这个值来指示是否胜利。流程图如下图4-2
29、:开始黑子下子白子下子是否有五子相连白子下子是否有五子相连结束是否否 图4-2 判断胜负流程图 由于这个算法所遵循的搜索顺序是从左到右、自上而下,因此在每次循环的时候,都有一些坐标无需纳入考虑范围。例如对于横向判断而言,由于右边界所限,因而所有横坐标大于等于11的点,都构不成达到五子连的条件,所以横坐标的循环上界也就定为11,这样也就提高了搜索的速度。4.2人机对弈算法人机对弈算法完全按照CGame基类定义的接口标准,封装在了COneGame派生类之中。下面将对这个算法进行详细地介绍。4.2.1获胜组合获胜组合是一个三维数组,它记录了所有取胜的情况。也就是说,参考于CTable:Win中的情况
30、,对于每一个落子坐标,获胜的组合一共有15*11*2+11*11*2=572种。而对于每个坐标的获胜组合,应该设置一个1515572大小的三维数组。在拥有了这些获胜组合之后,就可以参照每个坐标的572种组合给自己的局面和玩家的局面进行打分,也就是根据当前盘面中某一方所拥有的获胜组合多少进行权值的估算,给出最有利于自己的一步落子坐标。由于是双方对弈,所以游戏的双方都需要一份获胜组合,也就是: 电脑获胜组玩家获胜组合在每次游戏初始化的时候,需要将每个坐标下可能的获胜组合都置为true。在初始化的时候,将每个棋子数置为0。4.2.2落子后处理每当一方落子后,都需要作如下处理:如果己方此坐标的获胜组合
31、仍为true,且仍有可能在此获胜组合处添加棋子,则将此获胜组合添加棋子数加1;如果对方此坐标的获胜组合仍为true,则将对方此坐标的获胜组合置为false,并将对方此获胜组合添加棋子数置为-1(不可能靠此组合获胜)。4.2.3查找棋盘空位在计算机落子之前,需要查找棋盘的空位,所以需要一个SearchBlank成员函数完成此项工作,此函数需要进行不重复的查找,也就是说,对已查找过的空位进行标记,并返回找到空位的坐标。4.2.4落子打分找到空位后,需要对这个点的落子进行打分,这个分数也就是这个坐标重要性的体现。考虑到攻守两方面的需要,所以将玩家落子给的分数置为负值。4.2.5防守策略落子的考虑不单
32、单要从进攻考虑,还要从防守考虑。这一细节的实现其实就是让计算机从玩家棋盘布局分析战况,然后找出对玩家最有利的落子位置。4.2.6选取最佳落子 它的实现原理是:在四个方向上,各自计算那个方向上棋子的状态,我们的思路是利用原来定义的白棋为1,黑棋为-1,的思想,让同个方向上的五个棋子的值相加,取绝对值并赋值给为这个方向定义的局部变量。为什么要用五个棋子的值相加呢?因为,如果几个棋子是同色的,无论黑白,它的绝对值必然大,而对于几个棋子中有黑棋和白棋的,其值必然相加而抵消变小。所以我们可以利用这种方法来寻找旁边有多个同色棋子的空位置。在每一个棋盘位置,计算以它为起点的四个方向(上、下、右下、左下),再
33、比较这四个方向中哪个值最大,然后在这个方向上寻找落棋点。5 软件实现5.1游戏运行(1)游戏开始 自主选择是人机对战亦或是人人对战,还有先手问题,你先或是计算机先,音效是开活关。如下图5-1所示图 5-1 五子棋开始界面(2)游戏界面如下图5-2所示为于计算机对弈,你先下图 5-2 五子棋界面(3)游戏的工具栏-上有所需要的选项游戏难度选择可在游戏【G】上选择,新开局,英雄榜等等选项。如下图5-3所示。图5-3 五子棋游戏工具栏(4)悔棋在选项上可以选择悔棋选项如下图5-4。图5-4 选项 (5)游戏结束例如下图5-5所示图 5-5 游戏结束界面6补充说明考虑到程序的响应速度,人机对弈算法只对
34、玩家的棋子进行了一步的推测。由于计算机在落子时选取的是得分最高的一步落子,所以如果玩家在开局的时候不改变落子步骤,那么将会获得从头至尾相同的棋局。对于人机对弈的悔棋处理,由于这个算法的开销相当大,每一步落子都会存在不同的棋盘布局,所以实现从头到尾的悔棋不是很现实(将会存在过多的空间保存棋盘布局),因而在人机对弈模式下,只允许玩家悔最近的两步落子。7结论考虑到程序的响应速度,人机对弈算法只对玩家的棋子进行了一步的推测。由于计算机在落子时选取的是得分最高的一步落子,所以如果玩家在开局的时候不改变落子步骤,那么将会获得从头至尾相同的棋局。考虑到下棋同时还要聊天,所以并未对落子时间加入任何限制,同样如
35、果玩家离开游戏也不会判负。对于人机对弈的悔棋处理,由于这个算法的开销相当大,每一步落子都会存在不同的棋盘布局,所以实现从头到尾的悔棋不是很现实(将会存在过多的空间保存棋盘布局),因而在人机对弈模式下,只允许玩家悔最近的两步落子。 通过编写这个程序,我体会最为深刻的一点是系统架构和设计模式的重要性。即使是对于一个并不大的程序,代码的组织都是非常重要的,因为这关系到日后的维护以及扩展。这个游戏之中,有关网络Socket编程或者博弈树算法的知识都可以直接从无所不包的Internet上获取,甚至可以直接获得一个完整的五子棋人机对弈算法的源代码级模块。但是对于系统的架构,却完全是自己的事情,几千上万行的
36、代码需要通过合适的方法组织起来,使程序员编写代码更加有条理,更加符合软件工程的标准,这才是最重要的。在刚开始编写这个程序的时候,我幼稚地认为其中最重要的是博弈树算法。但是头一个月编写程序的时候却发现程序越写越不容易维护,可见是我走错了方向。后来我向公司真正的软件设计人员及系统架构师讨教,他们告诉我:我们的先人早已为我们准备好了各种精良可用的现成算法,我们所要做的就是直接“拿来主义”罢了;但是对于代码的组织(也就是软件的架构)才是真正软件工业的核心部分,因为软件事实上是直接和经济挂钩的,因此我们必须在编写代码之前选择一种最为合适的方法来组织这些代码,否则我们将会失去更多的时间和金钱。致谢最后在学
37、校的这几周,由于找工作和户籍的原因而无法抽出更多的时间来做好这毕业的要求,但在这么短的时间内还是有着现在这论文,最要感谢的还是我们刘博老师,因为他在读博期间还那么用心的帮助我们,还每周让我们汇报情况,帮助我们去修改一些错误。当然也要感谢给我帮助的好友们,给予我很多支持。参考文献1MSDNforVisualStudio6.02设计模式可复用面向对象软件的基础,ErichGamma/RichardHelm/Ralph Johnson/JohnVlissides著,李英军/马晓星/蔡敏/刘建中等译,机械工业出版社3深入浅出MFC(第2版),侯俊杰著,华中科技大学出版社4MicrosoftVisual
38、C+.NET技术内幕(第6版),GeorgeShepherd/DavidKruglinski著,潘爱民译,清华大学出版社5VisualC+网络通信协议分析与应用实现,汪晓平/钟军等编著,人民邮电出版社6C+编程思想,Bruce Eckel著,刘宗田/邢大红/孙慧杰等译,机械工业出版社721天学通C+,Jesse Liberty著,康博创作室译,人民邮电出版社8C+标准程序库,NicolaiM.Josuttis著,侯捷/孟岩译,华中科技大学出版社9Windows程序设计,CharlesPetzold著,北京博彦科技发展有限公司译,北京大学出版社10VisualC+.NET网络编程,易君编著,中国铁道出版社11博弈树搜索http:/202.113.96.26/wlkc/rengongzhineng/rengongzhineng/kejian/AI/Ai/chapter3/33.htm12五子棋的核心算法,蝈蝈俊.net13道法自然,王咏武/王咏刚著,电子工业出版社24