我一直在处理一个处理脚本来模拟Langton的Ant,但是我遇到的问题是它只会对角移动。我一直试图修复它一段时间,但我无法弄清楚导致问题的原因。我怀疑它可能与turn()函数有关。
以下是代码:
int[][] grid;
int row;
int col;
int dir = 0;
final int DIR_UP = 0;
final int DIR_RIGHT = 1;
final int DIR_DOWN = 2;
final int DIR_LEFT = 3;
void setup()
{
size(500, 500);
background(255);
grid = new int[width][height];
col = width / 2;
row = height / 2;
}
void draw()
{
go();
}
void go()
{
int pix = col + row * width;
int state = grid[row][col];
loadPixels();
if(state == 0)
{
turn(1);
grid[row][col] = 1;
pixels[pix] = color(255);
}
else
{
turn(-1);
grid[row][col] = 0;
pixels[pix] = color(0);
}
updatePixels();
move();
}
void turn(int rotation)
{
dir += rotation;
if(dir < 0)
{
dir = 3;
}
else if(dir > 3)
{
dir = 0;
}
// Does not work, can return negative values
//dir = (dir + rotation) % 4;
}
void move()
{
switch(dir)
{
case DIR_UP:
row--;
case DIR_RIGHT:
col++;
case DIR_LEFT:
col--;
case DIR_DOWN:
row++;
}
if(col < 0)
col = width - 1;
else if(col >= width)
col = 0;
if(row < 0)
row = height - 1;
else if(row >= height)
row = 0;
}
答案 0 :(得分:0)
请养成debugging your code的习惯。
特别是,逐步执行switch
声明:
switch(dir)
{
case DIR_UP:
row--;
case DIR_RIGHT:
col++;
case DIR_LEFT:
col--;
case DIR_DOWN:
row++;
}
dir
DIR_UP
时会发生什么?如果dir
DIR_RIGHT
,会发生什么?汇总一个简单的草图,使用dir
的硬编码值来测试这一部分。
final int DIR_UP = 0;
final int DIR_RIGHT = 1;
final int DIR_DOWN = 2;
final int DIR_LEFT = 3;
int dir = DIR_UP;
switch(dir)
{
case DIR_UP:
println("up");
case DIR_RIGHT:
println("right");
case DIR_LEFT:
println("left");
case DIR_DOWN:
println("down");
}
当dir
为DIR_UP
时,您会发现代码实际上也执行了所有其他方向。这是因为case
语句落后并继续执行。 case
声明就像一个&#34;从这里开始&#34;声明。如果您想避免执行其他情况,可以使用break
关键字来突破switch
语句:
final int DIR_UP = 0;
final int DIR_RIGHT = 1;
final int DIR_DOWN = 2;
final int DIR_LEFT = 3;
int dir = DIR_UP;
switch(dir)
{
case DIR_UP:
println("up");
break;
case DIR_RIGHT:
println("right");
break;
case DIR_LEFT:
println("left");
break;
case DIR_DOWN:
println("down");
break;
}
请养成在这样的小型隔离示例程序中工作的习惯,并请debug your code了解将来会发生什么。