-1
所以,代码编译和运行完美。然而,通常,康威的生命游戏会在一段时间后稳定下来,而这段代码无限期地运行而没有死亡分支,如果有人能够帮助我找出原因,我很乐意。康威的加工生命游戏
int[][] world;
int SCALE_FACTOR = 4;
float DENSITY = 0.1;
void setup() {
size(500,500);
world = new int[width/SCALE_FACTOR][height/SCALE_FACTOR];
for(int i = 0; i < width/SCALE_FACTOR; i++) {
for (int j = 0; j < height/SCALE_FACTOR; j++) {
int r = (int)random(100);
world[i][j] = r % (int)(1/DENSITY) == 0 ? 1 : 0;
}
}
frameRate(1);
stroke(0, 255, 0);
}
void draw() {
scale(SCALE_FACTOR);
background(0);
for(int i = 0; i < width/SCALE_FACTOR; i++) {
for (int j = 0; j < height/SCALE_FACTOR; j++) {
if (world[i][j] == 1) point(i, j);
}
}
lifeCycle();
}
void lifeCycle() {
int[][] newworld = new int[width/SCALE_FACTOR][height/SCALE_FACTOR];
for(int i = 0; i < width/SCALE_FACTOR; i++) {
for (int j = 0; j < width/SCALE_FACTOR; j++) {
if (world[i][j] == 1) {
if (neighbours(i, j) == 3) {
newworld[i][j] = 1;
} else {
newworld[i][j] = 0;
}
} else {
if (neighbours(i, j) == 2 || neighbours(i, j) == 3) {
newworld[i][j] = 1;
} else {
newworld[i][j] = 0;
}
}
}
}
for (int i = 0; i < width/SCALE_FACTOR; i++) {
for (int j = 0; j < height/SCALE_FACTOR; j++) {
world[i][j] = newworld[i][j];
}
}
}
int neighbours(int x, int y) {
int px = (x == width/SCALE_FACTOR - 1) ? 0 : (x+1);
int py = (y == height/SCALE_FACTOR - 1) ? 0 : (y+1);
int mx = (x == 0) ? (width/SCALE_FACTOR - 1) : (x-1);
int my = (y == 0) ? (height/SCALE_FACTOR - 1) : (y-1);
return world[mx][my] + world[mx][y] + world[mx][py]
+ world[x][my] + world[x][py]
+ world[px][my] + world[px][y] + world[px][py];
}
我想说这更适合http://codereview.stackexchange.com/ – 2013-02-28 19:20:24
一般策略:单元测试它的每一块。它看起来像if语句的分支在查看当前单元格是否存在或不存在时是落后的。也就是说,一个死细胞应该与三个邻居一起活着,一个活细胞应该与2/3个邻居共存。 – bchurchill 2013-02-28 19:21:21
请记住,第一次来这里,谢谢安德鲁 – 2013-02-28 19:28:38