我在学习了一些语言之后学会自己编写Java,并决定制作一个非图形化的Chess游戏。
第一个问题: 这是我在" Board.java"中的多维字符串列表:
public static String chessBoard[][][] = {
{ { "A1" }, { "A2" }, { "A3" }, { "A4" }, { "A5" }, { "A6" },
{ "A7" }, { "A8" } },
{ { "B1" }, { "B2" }, { "B3" }, { "B4" }, { "B5" }, { "B6" },
{ "B7" }, { "B8" } },
{ { "C1" }, { "C2" }, { "C3" }, { "C4" }, { "C5" }, { "C6" },
{ "C7" }, { "C8" } },
{ { "D1" }, { "D2" }, { "D3" }, { "D4" }, { "D5" }, { "D6" },
{ "D7" }, { "D8" } },
{ { "E1" }, { "E2" }, { "E3" }, { "E4" }, { "E5" }, { "E6" },
{ "E7" }, { "E8" } },
{ { "F1" }, { "F2" }, { "F3" }, { "F4" }, { "F5" }, { "F6" },
{ "F7" }, { "F8" } },
{ { "G1" }, { "G2" }, { "G3" }, { "G4" }, { "G5" }, { "G6" },
{ "G7" }, { "G8" } },
{ { "H1" }, { "H2" }, { "H3" }, { "H4" }, { "H5" }, { "H6" },
{ "H7" }, { "H8" } }, };
如果我在棋盘上放置一个棋子(来自" WPawn.java"):
A1 A2 A3 A4 A5 A6 A7 A8
WP1 B2 B3 B4 B5 B6 B7 B8
C1 C2 C3 C4 C5 C6 C7 C8
D1 D2 D3 D4 D5 D6 D7 D8
E1 E2 E3 E4 E5 E6 E7 E8
F1 F2 F3 F4 F5 F6 F7 F8
G1 G2 G3 G4 G5 G6 G7 G8
H1 H2 H3 H4 H5 H6 H7 H8
我希望结果列表(上面)返回原始列表(来自第一个代码),但我该怎么做?
提前致谢:)
public static void update() {
// Print chessBoard nicely
System.out.println("Here is the board: ");
for (int row = 0; row < chessBoard.length; row++) {
for (int column = 0; column < chessBoard[row].length; column++) {
for (int pos = 0; pos < chessBoard[row][column].length; pos++) {
System.out.print(chessBoard[row][column][pos] + "\t");
}
}
System.out.println();
}
// end
}
答案 0 :(得分:2)
不要质疑你当前的数据结构,我想你只需要做这样的事情
public class Chess {
/**
* @param args
*/
public static void main(String[] args) {
String[][][] chessBoard = initBoard();
//do what you want
//...
//reset
chessBoard = initBoard();
}
private static String[][][] initBoard() {
return new String[][][]{
{ { "A1" }, { "A2" }, { "A3" }, { "A4" }, { "A5" }, { "A6" }, { "A7" }, { "A8" } },
{ { "B1" }, { "B2" }, { "B3" }, { "B4" }, { "B5" }, { "B6" }, { "B7" }, { "B8" } },
{ { "C1" }, { "C2" }, { "C3" }, { "C4" }, { "C5" }, { "C6" }, { "C7" }, { "C8" } },
{ { "D1" }, { "D2" }, { "D3" }, { "D4" }, { "D5" }, { "D6" }, { "D7" }, { "D8" } },
{ { "E1" }, { "E2" }, { "E3" }, { "E4" }, { "E5" }, { "E6" }, { "E7" }, { "E8" } },
{ { "F1" }, { "F2" }, { "F3" }, { "F4" }, { "F5" }, { "F6" }, { "F7" }, { "F8" } },
{ { "G1" }, { "G2" }, { "G3" }, { "G4" }, { "G5" }, { "G6" }, { "G7" }, { "G8" } },
{ { "H1" }, { "H2" }, { "H3" }, { "H4" }, { "H5" }, { "H6" }, { "H7" }, { "H8" } }, };
}
}
答案 1 :(得分:0)
我通常更喜欢在内存中节省空间,所以当我想恢复数组时,我会使用以下方法:
public static void fill(String[][] grid) {
for (int y = 0; y < 8; y++) {
for (int x = 0; x < 8; x++) {
grid[y][x] = (char) (65 + y) + "" + (x + 1);
}
}
}
65是大写字母A的ASCII值,如果你不知道的话。该方法也将字母与数字一起递增。
另请注意,该方法使用的是 2D 数组,而不是 3D 数组,因此它 不会与您提供的数组一起使用。