【发布时间】:2014-01-03 04:30:08
【问题描述】:
我正在制作一个连续四个游戏,其中行数和列数由玩家决定(所以可以是任何东西,只要超过四个)。因此用户输入存储在变量“行”和“列”中。该字段看起来像这样,所以第一行总是数字。
我对获胜者的搜索算法有疑问。 虽然我的水平搜索算法工作正常,但具有相同逻辑的垂直搜索给了我超出范围的错误。如果你能帮我找出错误,我将非常感激。谢谢! 1 2 3 4 5 |-|-|-|-| |-|-|-|-| |-|-|-|-|
public static String checkWinner(String [][]field){
//horizontally, which works
for(int i=1; i<=rows; i++){
for (int j=0; j<=column-1;j++){
if (((j>=3 || j==column-1) && field[i][j]!="|_" && field[i][j]==field[i][j-1] && field[i][j]==field[i][j-2] && field[i][j]==field[i][j-3])
|| (field[i][j]!="|_" && field[i][j]==field[i][j+1] && field[i][j]==field[i][j+2] && field[i][j]==field[i][j+3]))
{
return field[i][j];
}
}
}
//vertically which doesn't work
for(int i=0; i<column; i++){
for (int j=1; j<=rows-1;j++){
if (((j>=4 || j==rows-1) && field[j][i]!="|_" && field[j][i]==field[j-1][i] && field[j][i]==field[j-2][i] && field[j][i]==field[j-3][i])
|| (field[j][i]!="|_" && field[j][i]==field[j+1][i] && field[j][i]==field[j+2][i] && field[j][i]==field[j+3][i]))
{
return field[i][j];
}
}
}
return null;
}
【问题讨论】:
-
请正确格式化您的代码,在当前状态下尝试通读非常痛苦
-
注意:
field[i][j]!="|_"。这不是您比较字符串的方式。使用equals()。 -
rows和column的值是什么 -
它们是用户给定的,所以可以是任意整数(但大于4才能玩游戏)。
标签: java multidimensional-array indexoutofboundsexception