当前位置: 首页 > news >正文

【LeetCode】37. Sudoku Solver

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.

 

这题跟N-Queens是一个套路,回溯法尝试所有解。

需要注意的区别是:

本题找到解的处理是return true,因此返回值为bool

N-Queen找到解的处理是保存解,因此返回值为void

 

对于每个空位'.',遍历1~9,check合理之后往下一个位置递归。

由于这里路径尝试本质上是有序的,即1~9逐个尝试,因此无需额外设置状态位记录已经尝试过的方向。

注意:只有正确达到最终81位置(即成功填充)的填充结果才可以返回,若不然,将会得到错误的填充。

因此辅助函数solve需要设为bool而不是void

class Solution {
public:
    void solveSudoku(vector<vector<char> > &board) {
        solve(board, 0);
    }
    bool solve(vector<vector<char> > &board, int position)
    {
        if(position == 81)
            return true;

        int row = position / 9;
        int col = position % 9;
        if(board[row][col] == '.')
        {
            for(int i = 1; i <= 9; i ++)
            {//try each digit
                board[row][col] = i + '0';
                if(check(board, position))
                    if(solve(board, position + 1))
                    //only return valid filling
                        return true;
                board[row][col] = '.';
            }
        }
        else
        {
            if(solve(board, position + 1))
            //only return valid filling
                return true;
        }
        return false;
    }
    bool check(vector<vector<char> > &board, int position)
    {
        int row = position / 9;
        int col = position % 9;
        int gid;
        if(row >= 0 && row <= 2)
        {
            if(col >= 0 && col <= 2)
                gid = 0;
            else if(col >= 3 && col <= 5)
                gid = 1;
            else
                gid = 2;
        }
        else if(row >= 3 && row <= 5)
        {
            if(col >= 0 && col <= 2)
                gid = 3;
            else if(col >= 3 && col <= 5)
                gid = 4;
            else
                gid = 5;
        }
        else
        {
            if(col >= 0 && col <= 2)
                gid = 6;
            else if(col >= 3 && col <= 5)
                gid = 7;
            else
                gid = 8;
        }

        //check row, col, subgrid
        for(int i = 0; i < 9; i ++)
        {
            //check row
            if(i != col && board[row][i] == board[row][col])
                return false;
            
            //check col
            if(i != row && board[i][col] == board[row][col])
                return false;
            
            //check subgrid
            int r = gid/3*3+i/3;
            int c = gid%3*3+i%3;
            if((r != row || c != col) && board[r][c] == board[row][col])
                return false;
        }
        return true;
    }
};

check的另一种实现方式如下:

bool check(vector<vector<char> > &board, int pos)
    {
        int v = pos/9;
        int h = pos%9;
        char target = board[v][h];
        //row
        for(vector<char>::size_type st = 0; st < 9; st ++)
        {
            if(st != h)
            {
                if(target == board[v][st])
                    return false;
            }
        }

        //col
        for(vector<char>::size_type st = 0; st < 9; st ++)
        {
            if(st != v)
            {
                if(target == board[st][h])
                    return false;
            }
        }

        //subgrid
        int beginx = v/3*3;
        int beginy = h/3*3;
        for(int i = beginx; i < beginx+3; i ++)
        {
            for(int j = beginy; j < beginy+3; j ++)
            {
                if(i != v && j != h)
                {
                    if(target == board[i][j])
                        return false;
                }
            }
        }

        return true;
    }

 

相关文章:

  • 融合成就卓越F5诠释“软件定义”新内涵
  • mysql 用户管理和权限设置
  • C语言之内存分配例题详解
  • 收费版APP三年总结(个人经验)
  • [原创]2014年上半年测试书籍推荐
  • VCL 中的 Windows API 函数(6): BeginDeferWindowPos
  • 用T4 Template生成代码
  • YourSQLDba 配置——修改备份路径
  • Asp.NET MVC 技术参考:http://kb.cnblogs.com/zt/mvc/
  • 【算法学习笔记】01.先说点什么吧
  • 更改Zend Studio/Eclipse代码风格主题
  • 06 Locking and Latching
  • 数学图形之球面,椭球面,胶囊体,刺球
  • contentType 'text/xml; charset=UTF-8' conflicts问题
  • Windows Azure创建管理数据库
  • 【译】JS基础算法脚本:字符串结尾
  • 分享的文章《人生如棋》
  • 10个最佳ES6特性 ES7与ES8的特性
  • JS基础之数据类型、对象、原型、原型链、继承
  • Laravel Mix运行时关于es2015报错解决方案
  • magento2项目上线注意事项
  • Python代码面试必读 - Data Structures and Algorithms in Python
  • Python利用正则抓取网页内容保存到本地
  • swift基础之_对象 实例方法 对象方法。
  • Web设计流程优化:网页效果图设计新思路
  • 动态魔术使用DBMS_SQL
  • 翻译 | 老司机带你秒懂内存管理 - 第一部(共三部)
  • 复习Javascript专题(四):js中的深浅拷贝
  • 来,膜拜下android roadmap,强大的执行力
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 入手阿里云新服务器的部署NODE
  • 思否第一天
  • 提醒我喝水chrome插件开发指南
  • 推荐一款sublime text 3 支持JSX和es201x 代码格式化的插件
  • FaaS 的简单实践
  • # 达梦数据库知识点
  • #Linux(权限管理)
  • #stm32整理(一)flash读写
  • #在 README.md 中生成项目目录结构
  • (02)Hive SQL编译成MapReduce任务的过程
  • (笔试题)合法字符串
  • (二)Eureka服务搭建,服务注册,服务发现
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (三)elasticsearch 源码之启动流程分析
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (四)Android布局类型(线性布局LinearLayout)
  • (四)Linux Shell编程——输入输出重定向
  • (一)Dubbo快速入门、介绍、使用
  • .\OBJ\test1.axf: Error: L6230W: Ignoring --entry command. Cannot find argumen 'Reset_Handler'
  • .FileZilla的使用和主动模式被动模式介绍
  • .halo勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .Net 8.0 新的变化
  • .net和jar包windows服务部署