有效的數獨 --枚舉

這道題僅僅是判斷是否能解開數獨 不要求解出來
有效的數獨 --枚舉
有效的數獨 --枚舉

class Solution {
    public boolean isValidSudoku(char[][] board) {
        for(int i = 0 ; i < 9  ;i++) {
            for(int j = 0 ; j < 9 ; j++) {
                char temp = board[i][j];
                board[i][j]='.';
                for(int x = 0 ; x < 9 ;x++) {
                        if(board[i][x]==temp||board[x][j]==temp)
                            return false;
                }
                for(int x = 0 ; x < 3 ; x++) {
                    for(int y = 0 ; y < 3 ; y++) {
                        if(board[i/3*3+x][j/3*3+y]==temp)
                            return false;
                    }
                }
                board[i][j] = temp;
            }
        }
        return true;
    }
}
class Solution {
    public boolean isValidSudoku(char[][] board) {
    for(int i = 0; i < 9; i++){
           for(int j = 0; j < 9; j++){
               if(board[i][j] == '.')continue;
               for(int k = 8; k > j; k--)
                   if(board[i][j] == board[i][k])
                       return false;
               for(int k = 8; k > i; k--)
                   if(board[i][j] == board[k][j])
                       return false;
               for(int k = i + 1; k % 3 != 0; k ++){
                   for(int h = j / 3 * 3;h < j / 3 * 3  + 3; h ++ )
                       if(board[i][j] == board[k][h]) 
                           return false;
               }
           }
       }
       return true;
  }}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章