leetcode 困难 —— 解数独(简单递归)
创始人
2025-05-28 10:10:09
0

(有点类似于 N 皇后,就是通过递归找可能的解法)

题目:
编写一个程序,通过填充空格来解决数独问题。
数独的解法需 遵循如下规则:
数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)
数独部分空格内已填入了数字,空白格用 ‘.’ 表示。

题解:
保存三个状态数组
flag1:每一行,已经选取的数
flag2:每一列,已经选取的数
flag3:每 3 * 3 的块,已经选取的数

可以通过状态压缩来保存状态(已经选取的数)
例,二进制 110010,即选了数组1,4,5

依次考虑每一个空白格的可能填入的数字
如果在对应的 行,列,块 中都没有选过对应的数字
则选取对应的数字,进行递归,判断下一个空白格

直到为所有的空白格找到填法

(官方题解里有一个优化思路是,先判断空白格取值只有一种的,相当于将可以确定的空白格先全部填入对应的数)

代码如下

class Solution {
public:int flag[9][9] = { 0 };int flag1[9] = { 0 };int flag2[9] = { 0 };int flag3[3][3] = { 0 };int res[9][9];bool solve(int f, int flag[9][9], int flag1[9], int flag2[9], int flag3[3][3]) {if(f == 81) {for(int i = 0; i < 9; i++) {for(int j = 0; j < 9; j++) {res[i][j] = flag[i][j] + '0';}}return true;}int ff = f + 1;while(ff < 81 && flag[ff / 9][ff % 9] != 0) ff++;int fflag[9][9];int fflag1[9];int fflag2[9];int fflag3[3][3];for(int i = 0; i < 9; i++) {fflag1[i] = flag1[i];fflag2[i] = flag2[i];fflag3[i / 3][i % 3] = flag3[i / 3][i % 3];for(int j = 0; j < 9; j++) {fflag[i][j] = flag[i][j];}}for(int i = 1; i <= 9; i++) {if(!((flag1[f / 9] >> i) & 1) && !((flag2[f % 9] >> i) & 1) && !((flag3[(f / 9) / 3][(f % 9) / 3] >> i) & 1)) {fflag[f / 9][f % 9] = i;fflag1[f / 9] += (1 << i);fflag2[f % 9] += (1 << i);fflag3[(f / 9) / 3][(f % 9) / 3] += (1 << i);if(solve(ff, fflag, fflag1, fflag2, fflag3)) {return true;}fflag[f / 9][f % 9] = 0;fflag1[f / 9] -= (1 << i);fflag2[f % 9] -= (1 << i);fflag3[(f / 9) / 3][(f % 9) / 3] -= (1 << i);}}return false;}void solveSudoku(vector>& board) {for(int i = 0; i < 9; i++) {for(int j = 0; j < 9; j++) {if(board[i][j] == '.') flag[i][j] = 0;else {flag[i][j] = board[i][j] - '0';flag1[i] += (1 << flag[i][j]);flag2[j] += (1 << flag[i][j]);flag3[i / 3][j / 3] += (1 << flag[i][j]);}   }}int f = 0;while(f < 81 && flag[f / 9][f % 9] != 0) f++;solve(f, flag, flag1, flag2, flag3);for(int i = 0; i < 9; i++) {for(int j = 0; j < 9; j++) {board[i][j] = res[i][j];}}}
};

相关内容

热门资讯

容芯致远获天使轮融资 2026年5月8日,北京容芯致远科技有限公司(简称“容芯致远”)宣布完成天使轮融资。本轮融资由万利达...
试管期间能运动吗?避开这些坑,... 做试管的姐妹都纠结:不动怕气血差、影响卵泡,动了又怕伤子宫、毁着床,到底该怎么办?其实试管不用“躺平...
原创 今... 2026年5月6日,国内金价算是彻底“凉”了一下,你看那AU9999现货黄金,直接跌到了1013元一...
美国5月消费者信心再创历史新低... 财联社5月8日讯(编辑 牛占林)随着中东战争持续推高能源价格,美国消费者信心本月继续下滑,并再度刷新...
“压高盛一头”!江西一精神病院... 蓝鲸新闻5月8日讯(记者 徐甘甘)5月8日,盛通股份(002599.SZ)一季报引发资本市场热议——...
2026年企业短视频能力升级:... 本篇将回答的核心问题 2026年企业短视频营销面临哪些关键挑战,有效应对策略是什么? 服务机构的能力...
江西一精神病院炒股炒成上市公司... 红星资本局5月8日消息,近日,上市公司盛通股份(002599.SZ)发布一季报,披露了前十大股东名单...
企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...