leetcode 37. 解数独 深搜

编写一个程序,通过已填充的空格来解决数独问题。
一个数独的解法需遵循如下规则:
数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。
空白格用 ‘.’ 表示。

public class _37 {
    public boolean check(int x,int y,char[][] board,char k){ //检查该数是否有效
        int xi=x/3*3; //取该数所处的格子
        int yi=y/3*3;
        for(int i=0;i<9;++i){  //横着检查是否有重复
            if(board[x][i]==k){
                return false;
            }
        }
        for(int i=0;i<9;++i){
            if(board[i][y]==k){ //竖着检查是否有重复
                return false;
            }
        }
        for(int i=xi;i<xi+3;++i){  //检查所处九宫格是否有重复
            for(int j=yi;j<yi+3;++j){
                if(board[i][j]==k){
                    return false;
                }
            }
        }
        return true;
    }

    public void solveSudoku(char[][] board) {
        dfs(0,0,board);
    }

    public boolean dfs(int x,int y,char[][] board){
        if(x==9){ //正确
            return true;
        }
        if(y==9){ //换行
            return dfs(x+1,0,board);
        }
        if(board[x][y]!='.'){  
            return dfs(x,y+1,board);
        }
        for(char i='1';i<='9';++i){
            if(check(x,y,board,i)){
                board[x][y]=i;  //替换
                if(dfs(x,y+1,board)){
                    return true;
                }
                board[x][y]='.'; //回溯
            }
        }
        return false;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值