2012-01-15 116 views
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; 
} 
+0

在底部附近的空'else'语句上可能会有另外两个编译错误。如果你解决这些问题有什么改变吗? (例如,将{}放在它们后面)编译器可能会对您的方法中的重要内容感到困惑。 – 2012-01-15 20:56:35

+0

这实际上解决了这个问题!谢谢!我想知道为什么我没有想到这件事...... ^^; – frozenxdreamer 2012-01-15 21:03:17

+0

@RussellZahniser你应该发布这个答案,以便他可以接受它。 – 2012-01-15 21:41:57

回答

0

的“其他人”语句在你的代码的底部扑朔迷离编译器了解循环内什么是重要的。如果你修复这个错误,另一个就会消失。

相关问题