康威生命游戏的问题(在 Java 中)

Bab*_*iff 1 java

我正在尝试用 Java 编写 conways 的生活游戏,但它没有正常工作。我的意思是,静物可以工作,但闪光灯和船只不行。

这是我的算法的代码,播种由单独的鼠标侦听器处理(按预期工作)。

    int[][] state1 = new int[80][80];
    int[][] state2 = new int[80][80];
    public void logic(){
        state2=state1;
        for(int i=0;i<80;i++){
            for(int j=0;j<80;j++){
                int sum=state1[(i-1+80)%80][j]+state1[(i-1+80)%80][(j-1+80)%80]+state1[i][(j-1+80)%80]+state1[(i+1)%80][(j-1+80)%80]+state1[(i+1)%80][j]+state1[(i+1)%80][(j+1)%80]+state1[i][(j+1)%80]+state1[(i-1+80)%80][(j+1)%80];

                if(sum!=2 && sum!=3){
                    state2[i][j]=0;
                }
                else if(sum==3){
                    state2[i][j]=1;
                }
            }
        }
        state1=state2;
    }
Run Code Online (Sandbox Code Playgroud)

ami*_*mit 5

state2=state1; 不是在做你认为它会做的事情。

它只会让两个变量引用同一个数组。

所以,你实际上是在改变你作为“最后一步”采取的相同矩阵

要解决它,您需要复制state1state2.