NIIT第十一天

上午

多维数组

1.数组是引用数据类型

排序

1.冒泡排序法

2.类冒泡排序法

下午

飞行棋游戏

1.项目策划

2.项目规则确认

3.项目模块确认

晚上

1.飞行棋游戏,项目框架的编写

笔记

1.数组也是引用数据类型

2.冒泡排序法:嵌套for循环,外层循环控制冒泡的轮数,内层循环负责将本轮循环的最小值调换到末尾

3.在equals()方法使用上,应该将不会发生空值写在前面,因为在a.equals(b)时,如果a是空值,将不可能调用equals()方法,导致空指针报错,而b为空则不会

NIIT第十一天、第十二天、第十三天

飞行棋游戏

《游戏设置》

(1)游戏素材

普通格子:【∷】幸运轮盘:【◎】地雷:【※】暂停:【▉】时空隧道:【〓】

玩家角色:【野、辅、力、魔、控】说明:用于在地图上显示玩家的位置图标

(2)游戏规则

1.玩家初始位置在第一个位置处,如:玩家第一次投掷骰子点数为1,则玩家进入到第二个格子(在地图中的索引是1)

2.如果玩家投掷骰子,在最终行进到某位置后,与其他玩家重叠,则其他玩家被踩回到初始位置,即第一位置处(最终位置:是指玩家在经历:点数、幸运轮盘、地雷等后,最后所在的位置)

3.玩家赢的标准:玩家移动后最终落在终点,则玩家赢,游戏结束;如果玩家落在了地图外,则倒退超出终点的格数

4.地图图标说明,以下均为玩家最后停留的位置为判定依据:

【◎】:幸运轮盘,玩法:会额外得到一次投掷骰子的机会,如果点数是1、2、3,则该玩家与此刻最前面的玩家互换位置,如果点数是4、5、6,则玩家再投掷一次骰子,根据点数前进一定位置

【※】:地雷,玩法:玩家会被炸晕,倒退6格,但是玩家不能被炸出地图外

【▉】:坐牢,玩法:玩家会被暂停投掷筛子一轮

【〓】:时空隧道,玩法:玩家会被传送到下一个时空隧道的位置,如果玩家所在时空隧道是最后一个,则玩家什么都不做,停留在该时空隧道

5.其他待定的规则

(3)游戏模块设置

1.游戏会分为两个循环模块:游戏菜单循环模块+轮回投掷点数模块

2.在游戏菜单循环模块中,主要会包含:菜单的显示方法、有些基本的菜单项显示(游戏说明、关于游戏)、游戏退出方法、开始游戏的入口,在本模块中还会确定玩家的数量,即是几人局,因为在存储玩家时,使用的是数组,而数组的长度是不可变的,因此,这个只需要确认一次,玩家之后再来一局的话,就不需要再重新选择了(强制不可再选择)

3.在开始游戏模块中个,主要负责游戏的所有逻辑处理,这里分为主方法、地图打印方法、游戏逻辑判断方法、其他辅助的方法;主方法负责每一轮的控制,地图打印负责实时的显示玩家在地图上的位置,游戏逻辑判断是本游戏的关键,负责玩家所行进格数的判断,及玩家在落点处会经历幸运轮盘、坐牢等玩法,其他辅助方法是为了避免可能在多处存在相同的代码,如:玩家在地图的位置,可以独立写成方法,用于实时的计算

(4)游戏目前的BUG

到目前游戏代码的编写结束和简单的测试,发现以下的缺陷或程序设计的错误:

1.地图的打印或玩家的位置的实时确定:在本程序中,在玩家掷完点数后,不是立即加到玩家的位置信息上,而是尽力虚拟的位置信息,待其他(坐牢、时空隧道等)信息都确认后,再将最后的真是位置加到玩家的位置信息上;经检测,这样会导致玩家“自己踩自己”的情况发生,如:玩家行进6格,结果踩到地雷被炸回6格,因为是采用虚拟的位置,这时系统会判断6格前有玩家的存在,因此发生自己踩自己的情况

解决办法:不采用虚拟的位置,每次掷点结束后即加到玩家的位置信息上,然后进行该位置的判断,继续进行玩家位置信息的加减

2.在玩家获得幸运转盘,并且和最前面的玩家交换时,发生了传递参数的出错,即最前面的玩家被拉到当前玩家的位置,但是由于参数传递错误,当前的玩家行进的格数并不是两者之间的差距,因此导致当前的玩家并没有行进到最前玩家的位置,待修复

3.游戏开始,玩家在选择角色的时候,应该动态的减去被选择的角色,即游戏不允许存在相同的角色

4.特定索引被玩家占用后的恢复问题,这个问题需要修复打印地图的一个缺陷,即不应该在地图信息中存入玩家的信息,而应该在打印地图时,动态的替代

5.比赛结束后,对于比赛的评价功能暂未编写

6.其他暂未发现的BUG

(5)游戏源码

http://www.kuaipan.cn/file/id_68788844752798025.htm

(6)评价

做项目,学的不是写代码,而是这个项目该如何实现,和在项目中能或学到了什么!

IT第十一天、第十二天、第十三天 - 数组的应用、飞行棋游戏的编写和总结的更多相关文章

  1. Java开发笔记(二十三)数组工具Arrays

    数组作为一种组合形式的数据类型,必然要求提供一些处理数组的简便办法,包括数组比较.数组复制.数组排序等等.为此Java专门设计了Arrays工具,该工具包含了几个常用方法,方便程序员对数组进行加工操作 ...

  2. java 基本语法(十三) 数组(六)数组的常见异常

    1.数组角标越界异常:ArrayIndexOutOfBoundsException int[] arr = new int[]{1,2,3,4,5}; // for(int i = 0;i <= ...

  3. Labview学习之路(十三)数组函数

    本文章介绍一下函数选版中的数组函数,一眼看懂没什么特殊地方的就不说了 (一)数组大小 返回I32类型的数或者数组. 什么是I32类型?就是32位有符号整型, 有符号什么意思?就是在32位数据中最高做符 ...

  4. C# 开源框架

    一.AOP框架        Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种 ...

  5. PHP 汉字数字互转(100以内)| PHP 汉字转数字 | PHP数字转汉字

    <?php function numDatabase(){ $numarr =array(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,2 ...

  6. C#开源系统大汇总(个人收藏)

    C#开源系统大汇总 一.AOP框架        Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖 ...

  7. C#常用开源类库

    一.AOP框架        Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种 ...

  8. .NET平台下开源框架

    一.AOP框架Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种部署方面(asp ...

  9. “K米” 软件产品评测

    第一部分 调研,评测 评测: 第一次上手体验:KTV相信很多人都有去过,大部分包厢只有哦一个点歌台,相信很多人都会烦恼于一堆人挤在小小的点歌台前点歌的样子,还有些人不太好意思跑到点歌台点歌,常常是碰到 ...

随机推荐

  1. hdu 2421 Deciphering Password(约数个数问题)

    http://acm.hdu.edu.cn/showproblem.php?pid=2421 A^B 能够写成 p1^e1 * p2^e2 * .....*pk^ek.(A.B <= 10000 ...

  2. Web前端开发工程师为什么讨厌IE6!

  3. DevExpress ASP.NET 使用经验谈(1)-XPO模型的创建

    这个系列通过一些简单例子循序渐进,介绍DevExpress ASP.NET控件的使用.先来介绍一下XPO的使用,安装的DevExpress版本为DXperienceUniversal-12.2.4,使 ...

  4. Android UiAutomator 自动化测试一些代码实例---新手3

    1.打开浏览器,打开百度实例 public void testBrowser() throws RemoteException, UiObjectNotFoundException{ //灭屏幕-亮屏 ...

  5. 设置MAVEN_OPTS的推荐方法

    运行mvn eclipse:eclipse时,经常会出现因为maven项目过大,导致内存不足java栈溢出的error,需要更改MAVEN启动内存 http://stackoverflow.com/q ...

  6. AngularJS Factory Service Provider

    先看看http://www.cnblogs.com/mbydzyr/p/3460501.html http://www.oschina.net/translate/angularjs-factory- ...

  7. HDU 3231 Box Relations

    题目大意: 给定一些正方体的关系,要求一组符合这些关系的正方体坐标,如果不存在符合条件的正方体坐标,IMPOSSIBLE.(Special Judge) 实力还是太弱了,完全不会…… #include ...

  8. Laravel后台 + AngularJS前端 的网站构建与维护

    最近维护的报修网站,采用Laravel+AngularJS框架搭建,还有很多东西需要熟悉掌握,现将修复的Bug或添加的功能中值得记录的地方总结如下. 其中,需要注意的问题基本是原因不明且不是太严重的问 ...

  9. poj 3128 Leonardo&#39;s Notebook(置换的幂)

    http://poj.org/problem?id=3128 大致题意:输入一串含26个大写字母的字符串,能够把它看做一个置换.推断这个置换是否是某个置换的平方. 思路:具体解释可參考url=ihxG ...

  10. HDU 2665(Kth number-区间第k大[内存限制+重数])

    Kth number Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...