0
我正在尝试检查棋子是否合法。当我使用它正在检查的变量时,我为每个循环使用了一次(仅一次),它给了我一个'无法解决的错误'。我在这发生的地方粗体显示。谁能帮忙? (是的,我知道这些代码还没有完成,我试图摆脱这种错误的第一次。)没有身体为什么在此代码中出现“无法解决”错误?
public boolean isLegal(Location loc1)
{
String currentColor = currentPlayer.getColor();
boolean isLegal = false;
int row = loc1.getRow();
int col = loc1.getCol();
if(board.isValid(loc1))
{
if(board.get(loc1) == null)
{
for(Location tempLoc : board.getValidAdjacentLocations(loc1))
{
if(!board.get(tempLoc).equals(currentColor))
{
int tempRow = tempLoc.getRow();
if((row != tempLoc.getRow()) && (col == tempLoc.getCol()))
{
//count up column
if(**tempLoc.getRow()** < row)
{
for(int i = row; i > 1;)
{
Location tempLoc2 = new Location(i-2, col);
if(!board.get(tempLoc2).equals(currentColor))
{
i--;
}
else
{
i=-1;
isLegal = true;
}
}
}
//count down column
else
{
for(int i = row; i < 6;)
{
Location tempLoc2 = new Location(i+2, lcol);
if(!board.get(tempLoc2).equals(currentColor))
{
i++;
}
else
i=9;
isLegal = true;
}
}
}
else if(col != tempLoc.getCol() && row == tempLoc.getRow())
{
//count left/right row
if(col > tempLoc.getCol())
{
}
else
}
else
{ //count up/right & down/left diag
if(1!=0)
{
}
//count up/left & down/right diag
else
}
}
}
}
}
return isLegal;
}
在底部附近的空'else'语句上可能会有另外两个编译错误。如果你解决这些问题有什么改变吗? (例如,将{}放在它们后面)编译器可能会对您的方法中的重要内容感到困惑。 – 2012-01-15 20:56:35
这实际上解决了这个问题!谢谢!我想知道为什么我没有想到这件事...... ^^; – frozenxdreamer 2012-01-15 21:03:17
@RussellZahniser你应该发布这个答案,以便他可以接受它。 – 2012-01-15 21:41:57