智能蛇算法

编写智能算法
编写人工智能程序,使得 snake 每秒自动走一步。

决定蛇行走的方向函数的伪代码

// Hx,Hy: 头的位置
// Fx,Fy:食物的位置
function whereGoNext(Hx,Hy,Fx,Fy) {
// 用数组movable[3]={“a”,”d”,”w”,”s”} 记录可走的方向
// 用数组distance[3]={0,0,0,0} 记录离食物的距离
// 分别计算蛇头周边四个位置到食物的距离。H头的位置,F食物位置
//     例如:假设输入”a” 则distance[0] = |Fx – (Hx-1)| + |Fy – Hy|
//           如果 Hx-1,Hy 位置不是Blank,则 distance[0] = 9999
// 选择distance中存最小距离的下标p,注意最小距离不能是9999
// 返回 movable[p]
}

智能蛇的程序框架

输出字符矩阵
WHILE not 游戏结束 DO
    wait(time)
    ch=whereGoNext(Hx,Hy,Fx,Fy)
    CASE ch DO
    ‘A’:左前进一步,break 
    ‘D’:右前进一步,break    
    ‘W’:上前进一步,break    
    ‘S’:下前进一步,break    
    END CASE
    输出字符矩阵
END WHILE
输出 Game Over!!! 

查阅资料认识到,可以有一条虚拟蛇去探路。

也了解了有一种bfs算法(宽/广度优先搜索)来搜寻吃到食物的最短路线。

你可能感兴趣的:(智能蛇算法)