【LeetCode 0037】【回溯/剪枝】解数独

  1. Sudoku Solver

Write a program to solve a Sudoku puzzle by filling the empty cells.

A sudoku solution must satisfy all of the following rules:

  • Each of the digits 1-9 must occur exactly once in each row.
  • Each of the digits 1-9 must occur exactly once in each column.
  • Each of the digits 1-9 must occur exactly once in each of the 9 3x3 sub-boxes of the grid.

The '.' character indicates empty cells.

Example 1:

复制代码
**Input:** board = [["5","3",".",".","7",".",".",".","."],["6",".",".","1","9","5",".",".","."],[".","9","8",".",".",".",".","6","."],["8",".",".",".","6",".",".",".","3"],["4",".",".","8",".","3",".",".","1"],["7",".",".",".","2",".",".",".","6"],[".","6",".",".",".",".","2","8","."],[".",".",".","4","1","9",".",".","5"],[".",".",".",".","8",".",".","7","9"]]
**Output:** [["5","3","4","6","7","8","9","1","2"],["6","7","2","1","9","5","3","4","8"],["1","9","8","3","4","2","5","6","7"],["8","5","9","7","6","1","4","2","3"],["4","2","6","8","5","3","7","9","1"],["7","1","3","9","2","4","8","5","6"],["9","6","1","5","3","7","2","8","4"],["2","8","7","4","1","9","6","3","5"],["3","4","5","2","8","6","1","7","9"]]
**Explanation:** The input board is shown above and the only valid solution is shown below:

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/3/31/Sudoku-by-L2G-20050714_solution.svg/250px-Sudoku-by-L2G-20050714_solution.svg.png" style="height:250px; width:250px">

Constraints:

  • board.length == 9
  • board[i].length == 9
  • board[i][j] is a digit or '.'.
  • It is guaranteed that the input board has only one solution.
JavaScript Solution
javascript 复制代码
/**
 * @param {character[][]} board
 * @return {void} Do not return anything, modify board in-place instead.
 */
var solveSudoku = function(board) {
    solve(board)
    
};
let solve = (board)=>{
    let len = board.length
    for(let row = 0 ; row < len; row ++ ){
        for(let col = 0; col < len; col ++){
            if(board[row][col] == '.'){
                for( let c = 1; c < 10; c++){
                    if(isValid(board,row,col,c)){
                        board[row][col] = String.fromCharCode(48+c)
                        if(solve(board)){
                            return true
                        }else{
                            board[row][col] = '.'
                        }
                    }           
                }
                return false         
            }
        }
    }
    return true
};
let isValid = (board,row,col,c)=>{
    for(let i = 0;i < 9 ;i++){
        if(board[i][col] == c)return false
        if(board[row][i] == c)return false
        if(board[3*Math.floor(row/3) + Math.floor(i/3) ][3*Math.floor(col/3) + (i%3) ] == c)return false
    }
    return true
}
相关推荐
core5129 小时前
PageRank 算法:互联网的“人气投票”
算法·pagerank
小白菜又菜9 小时前
Leetcode 1523. Count Odd Numbers in an Interval Range
算法·leetcode
你们补药再卷啦10 小时前
人工智能算法概览
人工智能·算法
cnxy18810 小时前
围棋对弈Python程序开发完整指南:步骤3 - 气(Liberties)的计算算法设计
python·算法·深度优先
AndrewHZ10 小时前
【图像处理基石】什么是光栅化?
图像处理·人工智能·算法·计算机视觉·3d·图形渲染·光栅化
小白菜又菜10 小时前
Leetcode 944. Delete Columns to Make Sorted
算法·leetcode
我找到地球的支点啦10 小时前
Matlab系列(006) 一利用matlab保存txt文件和读取txt文件
开发语言·算法·matlab
Dev7z11 小时前
基于Matlab实现GRACE卫星重力数据的全球水储量变化估算与分析
人工智能·算法·matlab
爱喝热水的呀哈喽11 小时前
11题目汇总
算法
三斗米12 小时前
Transformer入门:一文读懂《Attention Is All You Need》
算法·架构