LeetCode—37. 解数独(困难)

37. 解数独(困难)

题目描述:
编写一个程序,通过填充空格来解决数独问题。
数独的解法需 遵循如下规则:

数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)
数独部分空格内已填入了数字,空白格用 ‘.’ 表示。

考察重点:递归回溯(DFS)

方法概括:通过36中的判别方法,构建row,column,tube进行合法性判定,结合深度优先搜索对矩阵中的 ‘.’ 点位遍历所有可能填入数字。

public boolean Dfs(int i, int j, char[][] board, boolean[][] row, boolean[][] column, boolean[][] tube){    //后三个参数分别用来判断,当前位置(i,j)填入一数字后是否合法int p = i / 3 * 3 + j / 3;for(int a1 = 0;a1 < 9 ;a1 ++){      //遍历1-9,即该位置可以填入的所有数字if(!row[i][a1] && !column[j][a1] && !tube[p][a1]){//判断该位置填入相应数字后,是否负责数独规则row[i][a1] = true;column[j][a1] = true;tube[i / 3 * 3 + j / 3][a1] = true;board[i][j] = (char)(a1 + 1 + '0');int tj = j + 1;if (i == 8 && j == 8)return true;for(int ti = i;ti < 9;ti ++) {      //当前位置填入a1+1后,继续寻找并迭代下一个'.'位置for (; tj < 9; tj++) {if (board[ti][tj] == '.') {if (Dfs(ti, tj, board, row, column, tube))return true;ti = 10;break;}if (ti == 8 && tj == 8) //两处if (ti == 8 && tj == 8)分别用来做递归停止条件,即分别为board[8][8]是'.'和数字的情况return true;}tj = 0;     //因为遍历是从(i,j)开始找下一个,所以此处tj=0是配合循环实现矩阵遍历}row[i][a1] = false;     //填入a1无法满足后续位置满足条件,则向前回溯column[j][a1] = false;tube[i / 3 * 3 + j / 3][a1] = false;board[i][j] = '.';}}return false;}
public void solveSudoku(char[][] board) {boolean[][] row = new boolean[9][9];    // 9个长度为9的判别串。分别用来判断(i,j)上可以存放的数字,row[i][a1]=true 表示第i行已经存在a1boolean[][] column = new boolean[9][9];     //column[j][a1]=true 表示第j列已经存在a1boolean[][] tube = new boolean[9][9];//tube[i / 3 * 3 + j / 3][a1]=true 表示第i / 3 * 3 + j / 3个正方形内已经存在a1for(int i = 0;i < board.length;i ++)for(int j = 0;j < board[0].length;j ++){       //由于已经拥有一些数字,所以进行初始化if(board[i][j] != '.'){int a1 = board[i][j] - '0' - 1;row[i][a1] = true;column[j][a1] = true;tube[i / 3 * 3 + j / 3][a1] = true;}}for(int i = 0;i < board.length;i ++)         //寻找迭代起始位置,即第一个'.'for(int j = 0;j < board[0].length;j ++)if(board[i][j] == '.')Dfs(i, j, board, row, column, tube);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/263523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux下时间同步的两种方法分享

为什么80%的码农都做不了架构师&#xff1f;>>> 方法1&#xff1a;与一个已知的时间服务器同步 ntpdate time.nist.gov 方法2&#xff1a;linux自动同步时间vi /etc/crontab 00 0 1 * * root rdate -s time.nist.gov 转载于:https://my.oschina.net/boltwu/blo…

.Net TCP/UDP 编程 【一】【原创】

命名空间&#xff1a; using System.Net;using System.Net.Sockets; 关键 &#xff1a; TCP /UDP连接 UDP UDP 与 tCP的主要区别在于 UDP 不一定提供可靠的数据传输。事实上&#xff0c;该协议不能保证数据准确无误地到达目的地。UDP 在许多方面非常有效。当某个程序的目标是尽…

友元函数和友元类

友元函数是指某些虽然不是类成员却能够访问类的所有成员的函数。。类授予它的友元特别的访问权。通常同一个开发者会出于技术和非技术的原因&#xff0c;控制类的友元和成员函数&#xff08;否则当你想更新你的类时&#xff0c;还要征得其它部分的拥有者的同意&#xff09;。 /…

LeetCode—216. 组合总和 III

216. 组合总和 III 题目描述&#xff1a; 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9 每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次&#xff0c;组合可以以任何顺序返回。 考察重…

发表和编辑Post的一个Bug

其实这个Bug很早以前就发现了&#xff0c;只是一直忘了问dudu。在写Post的时候&#xff0c;当我需要改变字体颜色&#xff0c;例如选择红色时&#xff0c;文字的字体发生了改变。但当我第二次选择字体颜色&#xff0c;且选择相同的颜色时&#xff0c;选中的文字颜色就没有发生变…

maven配置_eclipse创建maven_maven插件配置

为什么80%的码农都做不了架构师&#xff1f;>>> 最近项目开发中需要使用maven。Maven这个东西是我2年前自学的。这2年之中基本没有使用过。现在项目需要&#xff0c;只有重新来一遍回锅肉。重新学习。经过一下午的斗争&#xff0c;一下午的各种问题各种解决&#x…

收藏

源码解析&#xff1a;http://www.iocoder.cn/categories/Sharding-JDBC/?cnblog java源码&#xff1a;http://blog.csdn.net/javazejian js 火狐文档&#xff1a;https://developer.mozilla.org/zh-CN/docs/Web/JavaScript NIO:http://www.iteye.com/magazines/132-Java-NIO J…

老生又长谈:HttpApplication,HttpModule,HttpContext及Asp.Net页生命周期

IIS在接到一个新的http请求后&#xff0c;最终会调用asp.net_isapi.dll的ISAPI扩展(特指IIS6.0环境&#xff0c;iis7.0的应用程序池默认为集成方式&#xff0c;相对有所变化)&#xff0c;然后传递到httpRuntime Pipe(http运行时管道)&#xff0c;Asp.Net这时才开始运行(即HttpR…

LeetCode—220. 存在重复元素 III

220. 存在重复元素 III 题目描述&#xff1a; 给你一个整数数组 nums 和两个整数 k 和 t 。请你判断是否存在 两个不同下标 i 和 j&#xff0c;使得 abs(nums[i] - nums[j]) < t &#xff0c;同时又满足 abs(i - j) < k 。 如果存在则返回 true&#xff0c;不存在返回 …

德里达逝世了!

放个标题在这里吧&#xff0c;追悼一下&#xff0e;-----------------------------------------------------某个人&#xff0c;您或者我&#xff0c;走上前来说&#xff1a;“最终&#xff0c;我要学会生活” !"生活&#xff0c;能够学会吗&#xff1f;能够教吗&#xff…

关于活动对像要注意的问题

如果用 RTime 中的 AT 方法&#xff0c;则这个时间不能比现在的时间小&#xff0c;否则 iStatus.Int() 将返回 -10 KErrUnderflow 这个错误 转载于:https://www.cnblogs.com/zziss/archive/2011/05/06/2039094.html

ByteBuffer常用方法详解

缓冲区(Buffer)就是在内存中预留指定大小的存储空间用来对输入/输出(I/O)的数据作临时存储&#xff0c;这部分预留的内存空间就叫做缓冲区&#xff1a; 使用缓冲区有这么两个好处&#xff1a; 1、减少实际的物理读写次数 2、缓冲区在创建时就被分配内存&#xff0c;这块内存区域…

LeetCode—221. 最大正方形

221. 最大正方形 题目描述&#xff1a; 在一个由 ‘0’ 和 ‘1’ 组成的二维矩阵内&#xff0c;找到只包含 ‘1’ 的最大正方形&#xff0c;并返回其面积。 考察重点&#xff1a;动态规划 方法概括&#xff1a;二维矩阵中查询最大矩形 dp[i][j] Min(dp[i-1][j],dp[i][j-1]…

发布Activex

1、如果需要创建cab文件&#xff0c;首先需要Cabarc或者Makecab&#xff0c;它们随着Cabinet SDK的安装就有了&#xff0c;Cabinet SDK的下载地址是http://msdn.microsoft.com/workshop/management/cab/cabdl.asp。 Cabarc可以创建、查看或者解出cab里面的文件&#xff0c;而…

做汉堡

其实我还是不太明白为什么要叫做汉堡&#xff0c;虽然我很喜欢吃汉堡..... 对于上次结对子作业的队友&#xff0c;小伙伴&#xff0c;我只想说一个字赞&#xff01;前所未有的感觉&#xff08;夸张了点&#xff09;... first&#xff0c;我们对整个任务没有做出工作量分析&…

Egret入门学习日记 --- 第二篇

第二篇&#xff08;学习篇&#xff09; 既然选好了Egret&#xff0c;那我就要想想怎么学了。 开始第一步&#xff0c;先加个Q群先&#xff0c;这不&#xff0c;拿到了一本《Egret HTML5游戏开发指南》&#xff0c;阅至三章&#xff0c;得到印象相对较深的好处和坏处&#xff1…

参加Sun公司的新产品的发布会议

在2004年的最后阶段&#xff0c;能收到Sun公司的邀请函&#xff0c;去参加“Sun秋季产品发布会”&#xff0c;是在沈阳的丽都喜来登酒店&#xff0c;幸运的是&#xff0c;这次地点是上次微软公司msdn发布会的邻居&#xff0c;也是五星级别的。不过这次去的时候&#xff0c;小妹…

LeetCode—222. 完全二叉树的节点个数

222. 完全二叉树的节点个数 题目描述&#xff1a; 给你一棵 完全二叉树的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达到最大值&#xff0c;并且最下…

编程珠玑读书笔记之磁盘文件排序

输入&#xff1a; 所输入的是一个文件&#xff0c;至多包含n个正整数&#xff0c;每个正整数都要小于n&#xff0c;这是 n 10^7。如果输入时某个整数出现了两次&#xff0c;就会产生一个致命的错误。这些整数与其他任何数据都不关联。 输出&#xff1a; 以增序形式输出的经过排…

辨别文件的真实类型

2019独角兽企业重金招聘Python工程师标准>>> 参考博客http://blog.csdn.net/shixing_11/article/details/5708145 每个文件类型都对应着一个编码头部 下面这些是已知的文件头部[自定义的枚举类型] package org.masque.file; /*** * Description:文件对应的文件头,资…