37. Sudoku Solver 回溯

2024-08-23 20:32
文章标签 37 回溯 sudoku solver

本文主要是介绍37. Sudoku Solver 回溯,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

Empty cells are indicated by the character '.'.

You may assume that there will be only one unique solution.



回溯问题:

思路:遍历所有的点 判断是否有效,有效则继续判断下一个点,无效则用下一个值尝试



public class Solution {public void solveSudoku(char[][] board) {solveSu(board);}private boolean solveSu(char [][] board){if(board==null||board.length==0) return false;for(int i=0;i<9;i++){                  //杭遍历for(int j=0;j<9;j++){		//列遍历if(board[i][j]=='.'){		//如果是 ‘.’开始试值for(char c='1';c<='9';c++){  if(isValidSu(board,i,j,c)){  //判断这个值在目前已经有的值的情况下 是否是有效的(局部有效) board[i][j]=c;	     //有效则给定这个值	if(solveSu(board))      //递归调用 return true;elseboard[i][j]='.';     //回溯 到上一层进行下一个值的尝试}}return false;//遍历过一遍for循环之后还没有成功就返回错误}}}return true;}private boolean isValidSu(char [][]board,int row,int col,char c){for(int i=0;i<board.length;i++){if(board[i][col]==c)return false;}for(int i=0;i<board[0].length;i++){if(board[row][i]==c)return false;}for(int i=row/3*3;i<row/3*3+3;i++){for(int j=col/3*3;j<col/3*3+3;j++){if(board[i][j]==c)return false;}}return true;}
}


这篇关于37. Sudoku Solver 回溯的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100428

相关文章

回溯——9.全排列

力扣题目链接 给定一个 没有重复 数字的序列,返回其所有可能的全排列。 示例: 输入: [1,2,3]输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ] 解题思路 问题建模:题目要求给出一个数组的所有排列组合,属于典型的全排列问题,这可以用回溯法来解决。回溯法通过递归的方式,依次将数组中的每个元素放入排列中,直到生成

风控系统之指标回溯,历史数据重跑

个人博客:无奈何杨(wnhyang) 个人语雀:wnhyang 共享语雀:在线知识共享 Github:wnhyang - Overview 回顾 默认你已经看过之前那篇风控系统指标计算/特征提取分析与实现01,Redis、Zset、模版方法。 其中已经介绍了如何利用redis的zset结构完成指标计算,为了方便这篇文章的介绍,还是在正式开始本篇之前回顾一下。 时间窗口 zset

165-Stamps【回溯】

回溯 给h和k的意思是在k种邮票中选h个邮票 基本的连续邮资问题 15226160 165 Stamps Accepted C++ 0.062 2015-03-27 07:21:37 #include<cstdio>#include<cstring>#include<algorithm>using namespace std;const int maxn = 2

回溯——8.递增子序列

力扣题目链接 给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2。 示例: 输入: [4, 6, 7, 7]输出: [[4, 6], [4, 7], [4, 6, 7], [4, 6, 7, 7], [6, 7], [6, 7, 7], [7,7], [4,7,7]] 说明: 给定数组的长度不会超过15。数组中的整数范围是 [-100,100]。给定数组中

NYOJ 37 回文字符串(记忆化搜索)

OJ题目 : 戳这里~~ 描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba"。当然,我们给你的问题不会再简单到判断一个字符串是不是回文字符串。现在要求你,给你一个字符串,可在任意位置添加字符,最少再添加几个字符,可以使这个字符串成为回文字符串。 输入 第一行给出整数N(0<N<100) 接下来的N行,每行一个字符串,每个字符串长度不超过1000.

【代码随想录|回溯part04】

代码随想录|回溯part04 1、46.全排列2、47.全排列 II3.问题 总结 python 1、46.全排列 46.全排列 class Solution:def permute(self, nums):result = []self.backtracking

代码随想录算法训练营第十九天| 回溯理论、77. 组合、216. 组合总和Ⅲ、17. 电话号码的字母组合

今日内容 回溯的理论基础leetcode. 77 组合leetcode. 216 组合总和Ⅲleetcode. 17 电话号码的字母组合 回溯理论基础 回溯法也叫回溯搜索法,它是一种搜索的方式,而且只要有递归就会有回溯,回溯就是递归的副产品。 回溯说到底并不是什么非常高深的搜索方式,本质上仍然是穷举,穷举所有可能然后选择出我们要的答案。剪枝会使回溯法更加高效一点,但改变不了回溯本质就是穷举

数据库系统 第37节 数据库快照

数据库快照是一种用于数据保护和恢复的技术,它可以创建数据库在某一特定时间点的完整副本,而不需要停止数据库服务。这种技术对于数据备份、灾难恢复、报告生成和分析等场景非常有用。数据库快照通常可以分为两种类型:行级快照和页级快照。 行级快照: 行级快照在数据库中为每一行数据维护一个版本历史记录。这意味着,当数据被修改时,旧版本的数据不会被立即删除,而是保留在数据库中,直到快照不再需要。这种快照方式允

LeetCode - 37. Sudoku Solver

37. Sudoku Solver  Problem's Link  ---------------------------------------------------------------------------- Mean:  求解数独. analyse: 只是9宫格的数独,而且测试数据都不难,所以可以直接使用递归求解,类似于N-Queue问题. 但如果宫格

LeetCode - 36. Valid Sudoku

36. Valid Sudoku  Problem's Link  ---------------------------------------------------------------------------- Mean:  给定一个数独,判断这个数独是否合法. analyse: 略. Time complexity: O(N)   view