leetcode第37题

简介: 从上到下,从左到右遍历每个空位置。在第一个位置,随便填一个可以填的数字,再在第二个位置填一个可以填的数字,一直执行下去直到最后一个位置。期间如果出现没有数字可以填的话,就回退到上一个位置,换一下数字,再向后进行下去。

image.png给定一个数独棋盘,输出它的一个解。

解法一 回溯法

从上到下,从左到右遍历每个空位置。在第一个位置,随便填一个可以填的数字,再在第二个位置填一个可以填的数字,一直执行下去直到最后一个位置。期间如果出现没有数字可以填的话,就回退到上一个位置,换一下数字,再向后进行下去。

publicvoidsolveSudoku(char[][] board) {
solver(board);
}
privatebooleansolver(char[][] board) {
for (inti=0; i<9; i++) {
for (intj=0; j<9; j++) {
if (board[i][j] =='.') {
charcount='1';
while (count<='9') {
if (isValid(i, j, board, count)) {
board[i][j] =count;
if (solver(board)) {
returntrue;
                        } else {
//下一个位置没有数字,就还原,然后当前位置尝试新的数board[i][j] ='.';
                        }
                    }
count++;
                }
returnfalse;
            }
        }
    }
returntrue;
}
privatebooleanisValid(introw, intcol, char[][] board, charc) {
for (inti=0; i<9; i++) {
if (board[row][i] ==c) {
returnfalse;
        }
    }
for (inti=0; i<9; i++) {
if (board[i][col] ==c) {
returnfalse;
        }
    }
intstart_row=row/3*3;
intstart_col=col/3*3;
for (inti=0; i<3; i++) {
for (intj=0; j<3; j++) {
if (board[start_row+i][start_col+j] ==c) {
returnfalse;
            }
        }
    }
returntrue;
}


时间复杂度:

空间复杂度:O(1)。

回溯法一个很典型的应用了。

相关文章
|
6月前
|
Java
leetcode-474:一和零
leetcode-474:一和零
39 0
|
6月前
|
消息中间件 Kubernetes NoSQL
LeetCode 3、28、1351
LeetCode 3、28、1351
LeetCode 389. 找不同
给定两个字符串 s 和 t,它们只包含小写字母。
71 0
leetcode第54题
在 leetcode 的 solution 和 discuss 看了下,基本就是这个思路了,只是实现上有些不同,怎么用来标记是否走过,当前方向,怎么遍历,实现有些不同,但本质上是一样的。就是充分理解题意,然后模仿遍历的过程。
103 0
leetcode第54题
leetcode第48题
将一个矩阵顺时针旋转 90 度,并且不使用额外的空间。大概属于找规律的题,没有什么一般的思路,观察就可以了。 解法一 可以先转置,然后把每列对称交换交换一下
leetcode第48题
|
算法
leetcode第34题
第二种思路,参考这里。 我们开始更新 start 的时候,是 mid + 1,如果剩两个元素,例如 2 4,target = 6 的话,此时 mid = 0,start = mid + 1 = 1,我们返回 start + 1 = 2。如果 mid 是右端点,那么 mid = 1,start = mid + 1 = 2,这样就可以直接返回 start 了,不需要在返回的时候加 1 了。
104 0
leetcode第34题
leetcode第39题
对回溯法又有了更深的了解,一般的架构就是一个大的 for 循环,然后先 add,接着利用递归进行向前遍历,然后再 remove ,继续循环。而解法二的动态规划就是一定要找到递进的规则,开始的时候就想偏了,导致迟迟想不出来。
leetcode第39题
leetcode第44题
时间复杂度:text 长度是 T,pattern 长度是 P,那么就是 O(TP)。 空间复杂度:O(TP)。 同样的,和第10题一样,可以优化空间复杂度。
leetcode第44题
leetcode第28题
返回一个字符串 needle 在另一个字符串 haystack 中开始的位置,如果不存在就返回 -1 ,如果 needle 长度是 0 ,就返回 0 。 就是一一比较就好,看下代码吧。
leetcode第28题
|
算法
leetcode第24题
解法一 迭代 首先为了避免单独讨论头结点的情况,一般先申请一个空结点指向头结点,然后再用一个指针来遍历整个链表。 先来看一下图示:
leetcode第24题