康威的生活游戏问题

时间:2013-03-01 00:28:02

标签: java eclipse

这是我为我的任务提供的代码。任务是找到代码的错误。该代码应该实现“康威的生命游戏”: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();
    }

1 个答案:

答案 0 :(得分:2)

我不会为你做任务(找到错误)。但这是一个策略:

  1. 代码是否编译?如果没有,请修复此问题。
  2. 程序运行时会崩溃吗?如果是这样,请查看堆栈跟踪以获取线索。然后使用调试器。
  3. 如果程序在没有崩溃的情况下运行但没有正确推进游戏,请尝试使用简单的Game of Life配置,您可以手动计算预期结果并查找代码的不同行为。
  4. 对于步骤2和3,掌握使用调试器的基础知识非常重要。祝你好运。