庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>安全技术>软件破解>算法研究>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

贪吃蛇的算法分析(1)

 作者:本站收集   日期:2005-5-28
字号选择〖 〗/ 双击滚屏 单击停止   
贪吃蛇是一款非常经典的手机游戏。它有很多算法,这里详细分析一种比较优秀的算法。
首先介绍下主要用到的七个类:

l         WormMain:最主要的类,控制所有其它类的运行和销毁。

l         WormPit:处理键盘输入事件并实例化Worm类和WormFood类的。

l         Worm:抽象了贪吃蛇的属性和动作

l         WormFood:抽象了食物的属性和动作

l         WormScore:用来纪录分数的类

l         WormLink:抽象了蛇身上的一段,保存了这段的坐标、方向和所有状态。

l         WormException:处理异常类

 

基本概念介绍

节:一条蛇可以看成有许多正方形的“小格子”拼凑成,我把它称作节。节是蛇身上最小的单位。

段:当许多节连成一条直线,我称它为段。上图的贪吃蛇只有一段,如果它拐弯就变成两段。

链表:用来保存每一段的状态,链表的元素单位是段。且链表的最后一个元素表示蛇的头部段。

坐标系:MIDP中的坐标以左上角那点为(0,0),向右则x递增,向下则y递增。

 

Worm类

一条完整的贪吃蛇是由一段一段组成的。链表中保存的第一个元素是蛇的尾巴段,最后一个元素是蛇的头部段。当蛇运动的时候,它头部段增加一节而尾段减少一节。如果它吃到了食物,尾部段就不减少一节。也就是说,蛇是从头部段开始长的。

 

下面的代码段显示了Worm类保存的各种属性:

    /* 贪吃蛇可能移动的方向 */

    public final static byte DOWN  = 2;

    public final static byte LEFT  = 4;

    public final static byte RIGHT = 6;

    public final static byte UP    = 8;

    // 贪吃蛇的当前方向

    private byte currentDirection;

    // 保存贪吃蛇每一段的列表

    private Vector worm = new Vector(5, 2);

    // 是否需要更新状态

    private boolean needUpdate;

    // 是否在运动中

    private boolean moveOnNextUpdate;

    // 是否吃到食物

    private boolean hasEaten;

    // 贪吃蛇的初始位置、长度和方向

    private final static int INIT_X = 3;

    private final static int INIT_Y = 8;

    private final static int INIT_LEN = 8;

    private final static byte INIT_DIR = RIGHT;

上一篇:算法分析报告(1.2) 上    下一篇:贪吃蛇的算法分析(2)  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-5-28
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿