судоку игровой конструктор - PullRequest
2 голосов
/ 21 мая 2011

У меня проблемы с инициализацией конструктора без параметров с определенной игрой. Почему-то он продолжает возвращать null, если я использую метод получения, чтобы вернуть игру. Может кто-нибудь сказать мне, что будет лучшим способом для инициализации игры?

В настоящее время я вызываю метод из другого класса, у которого есть статический метод, но, похоже, он не работает, потому что он выдает значение null, если я получаю игру.

Вот как мне эта игра быть:

           {{7,8,1,0,0,4,0,0,6},
            {2,0,9,3,6,0,1,0,0},
            {6,0,0,0,9,0,8,0,0},
            {0,0,0,0,3,5,0,0,0},
            {3,5,0,0,0,0,0,1,9},
            {0,0,0,4,2,0,0,0,0},
            {0,0,3,0,1,0,0,0,8},
            {0,0,7,0,8,3,4,0,1},
            {9,0,0,6,0,0,5,7,3}},

public class SudokuPlayer
{
    private int [][]  game;
    public enum CellState { EMPTY, FIXED, PLAYED };
    private CellState[][] gamestate;

    private static final int GRID_SIZE=9;

    public SudokuPlayer()
    {
        int[][] copy= SudokuGames.getGame(4);
        int size = copy.length;
        int[][] game = new int[GRID_SIZE][GRID_SIZE];
        for ( int row = 0; row < size; row++)
        {
            for ( int col =0; col < size; col++)
            {
                game[row][col] = copy[row][col];
            }
        }
    }

    public int[][] getGame()
    {
        return game;
    }
}

вот метод из другого класса, который я вызываю:

public class SudokuGames {

    public static final int [][][] GAMES = {
            // Game 0 VE - DEFAULT 30 squares filled
            {{5,3,0,0,7,0,0,0,0},
                {6,0,0,1,9,5,0,0,0},
                {0,9,8,0,0,0,0,6,0},
                {8,0,0,0,6,0,0,0,3},
                {4,0,0,8,0,3,0,0,1},
                {7,0,0,0,2,0,0,0,6},
                {0,6,0,0,0,0,2,8,0},
                {0,0,0,4,1,9,0,0,5},
                {0,0,0,0,8,0,0,7,9}},
            // Game 1 VE
            {{8,0,1,0,3,7,0,5,6},
                {0,0,0,9,0,0,0,0,7},
                {6,0,3,0,1,2,0,9,0},
                {0,2,0,0,0,0,7,0,3},
                {3,0,0,0,2,0,0,0,9},
                {1,0,9,0,0,0,0,8,0},
                {0,3,0,2,7,0,4,0,1},
                {7,0,0,0,0,6,0,0,0},
                {5,6,0,1,9,0,3,0,8}},
            // Game 2 VE
            {{0,9,0,0,3,0,1,4,0},
                {7,0,3,0,0,4,0,0,8},
                {5,0,0,6,0,7,0,2,0},
                {0,7,4,5,0,2,9,0,0},
                {1,0,0,0,0,0,0,0,2},
                {0,0,9,1,0,8,4,6,0},
                {0,5,0,7,0,9,0,0,6},
                {4,0,0,2,0,0,5,0,1},
                {0,8,6,0,5,0,0,7,0}},
            // Game 3 VE
            {{0,0,9,7,3,0,5,2,6},
                {0,0,5,0,2,0,8,0,0},
                {6,0,8,0,0,0,0,4,7},
                {0,0,0,0,0,9,0,6,2},
                {0,4,0,6,0,3,0,8,0},
                {8,9,0,5,0,0,0,0,0},
                {2,6,0,0,0,0,1,0,8},
                {0,0,7,0,1,0,6,0,0},
                {9,5,1,0,6,4,2,0,0}},
            // Game 4 VE
            {{7,8,1,0,0,4,0,0,6},
                {2,0,9,3,6,0,1,0,0},
                {6,0,0,0,9,0,8,0,0},
                {0,0,0,0,3,5,0,0,0},
                {3,5,0,0,0,0,0,1,9},
                {0,0,0,4,2,0,0,0,0},
                {0,0,3,0,1,0,0,0,8},
                {0,0,7,0,8,3,4,0,1},
                {9,0,0,6,0,0,5,7,3}},
            // Game 5 E
            {{0,0,0,9,1,0,0,0,2},
                {5,0,0,0,0,0,0,0,0},
                {3,0,0,5,4,0,0,6,8},
                {0,4,2,7,0,0,3,0,5},
                {0,0,3,4,5,6,2,0,0},
                {1,0,9,0,0,8,7,4,0},
                {8,1,0,0,7,5,0,0,4},
                {0,0,0,0,0,0,0,0,1},
                {9,0,0,0,8,4,0,0,0}},
            // Game 6 E
            {{0,0,0,1,0,7,0,9,0},
                {0,0,0,4,9,0,3,0,0},
                {6,0,0,0,3,0,4,1,0},
                {4,0,5,0,0,0,0,3,0},
                {8,2,0,0,0,0,0,5,4},
                {0,3,0,0,0,0,2,0,6},
                {0,1,4,0,7,0,0,0,5},
                {0,0,8,0,2,5,0,0,0},
                {0,6,0,8,0,1,0,0,0}},
            // Game 7 E
            {{0,0,2,8,0,7,5,0,0},
                {6,0,0,0,0,0,0,0,4},
                {0,8,0,0,6,0,0,7,0},
                {1,3,0,4,0,9,0,2,5},
                {0,0,0,0,0,0,0,0,0},
                {4,5,0,7,0,1,0,6,8},
                {0,6,0,0,3,0,0,9,0},
                {5,0,0,0,0,0,0,0,7},
                {0,0,1,6,0,4,2,0,0}}
        };  //End

    /**
     * getGame(int gameID) returns a a Sudoku game as int [][]
     *  as specified by the gameID. If the gameID is outside the
     *  list of possible games, null is returned.
     *  @param gameID number of game to be played
     *  @return int[][] a game to be played
     */
    public static int [][] getGame (int gameID) {

        /** A little dangerous. A copy of the reference to the original array
         * is returned. Not a copy of the array.
         **/
        if (gameID >= 0 && gameID < GAMES.length) {
            return GAMES[gameID];
        }
        else {
            return null;
        }

    }
}

1 Ответ

5 голосов
/ 21 мая 2011

Вы скрываете переменную экземпляра.

Измените следующее

int[][] game = new int[GRID_SIZE][GRID_SIZE];

на

game = new int[GRID_SIZE][GRID_SIZE];
...