LeetCode OJ: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.

A sudoku puzzle...

...and its solution numbers marked in red.
dfs,一直寻找,不行返回即可:
 class Solution {
 public:
     void solveSudoku(vector<vector<char>>& board) {
         doSudoku(board);
     }
     bool checkValid(vector<vector<char>>&board, int x, int y)
     {
         for(int i = ; i < ; i++){
             if(i!=x)
                 if(board[i][y] == board[x][y]) return false;
         }
         for(int j = ; j < ; j++){
             if(j != y)
                 if(board[x][j] == board[x][y]) return false;
         }
         for(int i = (x/) * ; i < (x/ + ) * ; ++i){
             for(int j = (y/) * ; j < (y/ + ) * ; ++j){
                 if((i!=x) || (j != y))
                     if(board[x][y] == board[i][j]) return false;
             }
         }
         return true;
     }
     bool doSudoku(vector<vector<char>> & board)
     {
         for(int row = ; row < ; ++row){
             for(int col = ; col < ; ++col){
                 if(board[row][col] == '.'){
                     for(int i = ; i <= ; ++i){
                         board[row][col] = '' + i;
                         if(checkValid(board, row, col)){
                             if(doSudoku(board)){
                                 return true;
                             }
                         }
                         board[row][col] = '.';
                     }
                     return false;
                 }
             }
         }
         return true;
     }
 };
LeetCode OJ:Sudoku Solver(数独游戏)的更多相关文章
- leetcode 37. Sudoku Solver 36. Valid Sudoku 数独问题
		三星机试也考了类似的题目,只不过是要针对给出的数独修改其中三个错误数字,总过10个测试用例只过了3个与世界500强无缘了 36. Valid Sudoku Determine if a Sudoku ... 
- [LeetCode] Valid Sudoku 验证数独
		Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could be ... 
- 【leetcode】Sudoku Solver
		Sudoku Solver Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells are i ... 
- Leetcode0037--Sudoku Solver 数独游戏
		[转载请注明]http://www.cnblogs.com/igoslly/p/8719622.html 来看一下题目: Write a program to solve a Sudoku puzzl ... 
- LeetCode 037 Sudoku Solver
		题目要求:Sudoku Solver Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells ... 
- [LeetCode] 37. Sudoku Solver 求解数独
		Write a program to solve a Sudoku puzzle by filling the empty cells. A sudoku solution must satisfy ... 
- [leetcode]37. Sudoku Solver 解数独
		Write a program to solve a Sudoku puzzle by filling the empty cells. A sudoku solution must satisfy ... 
- LeetCode 37 Sudoku Solver(求解数独)
		题目链接: https://leetcode.com/problems/sudoku-solver/?tab=Description Problem : 解决数独问题,给出一个二维数组,将这个数独 ... 
- Java [leetcode 37]Sudoku Solver
		题目描述: Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells are indicated ... 
- [Leetcode] valid sudoku 有效数独
		Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could be ... 
随机推荐
- python3 驱动 PyMySQL
			Python版本: 3.5.0 MySqlDB官网只支持Python3.4, 使用第三方库PyMysql连接Mysql数据库. https://pypi.python.org/pypi/PyMySQ ... 
- U盘在制作Ubuntu启动盘后Windows系统下显示空间不对的解决办法(Ubuntu系统下格式化U盘的方法)
			用Ubuntu系统自带的启动盘制作工具后,将U盘拿到Windows系统下使用显示出的空间与U盘大小不同. 解决该问题的办法: 使用Linux终端: 第一步:sudo fdisk -l 这个命令主要是查 ... 
- Java 安装教程(Eclipse) + 汉化 +  简单创建java项目
			Java 安装教程(Eclipse) 要安装Java 要分两个步骤: 1.JDK的安装 2.Eclipse的安装 3.Eclipse汉化 4.Eclipse创建简单java项目 1和2的顺序不能颠倒, ... 
- [BZOJ1996] chorus合唱队
			Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT 区间$dp$,首先每个点被放入队伍时队 ... 
- java并发容器之 SynchronousQueue [转]
			SynchronousQueue 这个队列实现了 BlockingQueue接口 该队列的特点 1.容量为0,无论何时 size方法总是返回0 2. put操作阻塞,jquery插件库 直到另外一个 ... 
- Servlet3.0整合Springmvc(注解版)
			在创建maven的web工程时候,如果报错缺少web.xml 则在pom添加如下配置 : <build> <plugins> <plugin> <groupI ... 
- LeetCode——Unique Paths
			Question A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram be ... 
- Linux 修改SSH端口及禁用ROOT远程SSH登陆
			打开配置文件: vim /etc/ssh/sshd_config 修改Port及PermitRootLogin节点 : //默认为yes 允许 no表示禁止 PermitRootLogin no // ... 
- TP5接受Vue跨域请求
			<?php /** * Created by PhpStorm. * User: qianglong * Date: 2018/1/15 * Time: 17:56 */ namespace a ... 
- 【Network Architecture】Feature Pyramid Networks for Object Detection(FPN)论文解析(转)
			目录 0. 前言 1. 博客一 2.. 博客二 0. 前言 这篇论文提出了一种新的特征融合方式来解决多尺度问题, 感觉挺有创新性的, 如果需要与其他网络进行拼接,还是需要再回到原文看一下细节.这里 ... 
