51| 数独

代码实现

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 10;
int a[N][N];
bool col[N][N], row[N][N], st[3][3][N];
bool dfs(int x, int y)
{
	// 出口
	if(y == 10)
	{
		x ++;
		y = 1;
	 } 
	if(x == 10) return true;
	if(a[x][y]) return dfs(x, y+1); // 已经填值了 
	for(int i = 1; i <= 9; i++)
	{
		if(row[x][i] || col[y][i] || st[(x-1)/3][(y-1)/3][i]) continue; // 剪枝
		 // 递归搜索
		 row[x][i] = col[y][i] = st[(x-1)/3][(y-1)/3][i] = 1;
		 a[x][y] = i; 
		 if(dfs(x, y+1)) return true; // 已经找到结果 
		 // 回溯 
		 row[x][i] = col[y][i] = st[(x-1)/3][(y-1)/3][i] = 0;
		 a[x][y] = 0; 
	 } 
	 return false; // 前面有填错了 
}
int main()
{
	for(int i = 1; i <= 9; i++)
	{
		for (int j = 1; j <= 9; j++)
		{
			int x; cin >> x;
			a[i][j] = x;
			if(x)	row[i][x] = col[j][x] = st[(i-1)/3][(j-1)/3][x] = 1; // 标记 
		}
	}
	dfs(1,1);
	for(int i = 1; i <= 9; i++)
	{
		for (int j = 1; j <= 9; j++) cout << a[i][j] << " ";
		cout << endl; 
	}
	return 0;
}
相关推荐
Liangwei Lin9 分钟前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾11 分钟前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困13 分钟前
leetGPU
算法
我星期八休息24 分钟前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛29 分钟前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你911 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i2 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪
paeamecium2 小时前
【PAT甲级真题】- String Subtraction (20)
数据结构·c++·算法·pat考试·pat
YL200404262 小时前
047从前序与中序遍历序列构造二叉树
算法·leetcode
极梦网络无忧2 小时前
password_hash
算法·哈希算法