-3

这是我为我的任务提供的代码。任务是找出代码有什么问题。该代码应该实现“康威的生命游戏”:http ://en.wikipedia.org/wiki/Conway 's_Game_of_Life 我找不到错误在哪里。

import java.util.Scanner;
import javax.swing.JFrame;

public class GameOfLife {

    public static void main(String[] args) {
        final int testCase = 1;

        JFrame frame = new JFrame();
        frame.setSize(500, 500);
        frame.setTitle("Conway's Game of Life");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        Cell[][] universe = new Cell[100][100];
        for (int x = 0; x < universe.length-1; x++) {
            for (int y = 0; y < universe[x].length-1; y++) {
                universe[x][y] = new Cell();
            }
        }

        if (testCase == 1) {
            universe[3][2].calculateNext(3);
            universe[3][2].updateCurrent();
            universe[3][3].calculateNext(3);
            universe[3][3].updateCurrent();
            universe[3][4].calculateNext(3);
            universe[3][4].updateCurrent();
        } else if (testCase == 2) {
            universe[49][50].calculateNext(3);
            universe[49][50].updateCurrent();
            universe[49][51].calculateNext(3);
            universe[49][51].updateCurrent();
            universe[50][49].calculateNext(3);
            universe[50][49].updateCurrent();
            universe[50][50].calculateNext(3);
            universe[50][50].updateCurrent();
            universe[51][50].calculateNext(3);
            universe[51][50].updateCurrent();
        } else {
        }

        UniverseComponent component = new UniverseComponent(universe);
        frame.add(component);

        frame.setVisible(true);

        Scanner in = new Scanner(System.in);
        String input = in.nextLine();
        while (input.length() == 0) {
            int neighborCount = 0;
            for (int x=1; x<universe.length-2; x++) {
                for (int y=1; y<universe[x].length-2; y++) {
                    neighborCount = 0;
                    if (universe[x-1][y-1].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x-1][y].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x-1][y+1].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x][y-1].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x][y+1].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x+1][y-1].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x+1][y].isAlive()) {
                        neighborCount++;
                    }
                    if (universe[x+1][y+1].isAlive()) {
                        neighborCount++;
                    }
                    universe[x][y].calculateNext(neighborCount);
                }
            }
            for (int x=1; x<universe.length-2; x++) {
                for (int y=1; y<universe[x].length-2; y++) {
                    universe[x][y].updateCurrent();
                }
            }
            component.repaint();
            input = in.nextLine();
        }
        in.close();
    }
4

1 回答 1

2

我不会为你做你的任务(找出错误)。但这里有一个策略:

  1. 代码是否编译?如果没有,请修复它。
  2. 程序运行时会崩溃吗?如果是这样,请查看堆栈跟踪以获取线索。然后使用调试器。
  3. 如果程序运行时没有崩溃但没有正确推进游戏,请尝试一个简单的 Game of Life 配置,您可以手动计算预期结果并查找代码行为不同的地方。

对于第 2 步和第 3 步,掌握使用调试器的基础知识很重要。祝你好运。

于 2013-03-01T00:33:06.493 回答