POJ 2676 Sudoku dfs

题意:九宫格游戏。给定一个九宫格,他的每一行每一列以及每一个3*3的子格都必须由1,2,3,4,5,6,7,8,9组成。不能多也不能少。求出一种满足条件的填充方案。

题解:貌似正搜得效率比反搜差不少。不过没关系,道理理解可就ok了。

#include <iostream>
using namespace std;

#define N 11
char str[N];
int map[N][N];
bool row[N][N], col[N][N], sub[N][N];
/* row[i][j]表示第i行的数j已经存在, col[i][j]表示第i列的数j已经存在,sub[i][j]同理 */
bool dfs ( int k )
{
	if ( k < 0 )
		return true;

	int r = k / 9;
	int c = k % 9;
	int sub_id = (r / 3) * 3 + c / 3;

	if ( map[r][c] != -1 )
		return dfs ( k - 1 );

	int temp = map[r][c];
	for ( int i = 0; i < 9; i++ )
	{
		if ( ! row[r][i] && ! col[c][i] && ! sub[sub_id][i] )
		{
			map[r][c] = i;
			row[r][i] = col[c][i] = sub[sub_id][i] = true;
			if ( dfs ( k - 1 ) )
				return true;
			map[r][c] = temp;
			row[r][i] = col[c][i] = sub[sub_id][i] = false;
		}
	}
	return false;
}

int main()
{
	int t, sub_id, i, j;
	scanf("%d",&t);
	while ( t-- )
	{
		memset(row,0,sizeof(row));
		memset(col,0,sizeof(col));
		memset(sub,0,sizeof(sub));

		for ( i = 0; i < 9; i++ )
		{
			scanf("%s",str);
			for ( j = 0; j < 9; j++ )
			{
				map[i][j] = str[j] - '0' - 1; /* 数字取的是0-8,所以输出时要加1 */
				if ( map[i][j] < 0 ) continue;
				sub_id = (i / 3) * 3 + j / 3;
				row[i][map[i][j]] = true;
				col[j][map[i][j]] = true;
				sub[sub_id][map[i][j]] = true;
			}
		}

		if( dfs ( 80 ) )
		{
			for ( i = 0; i < 9; i++ )
			{
				for ( j = 0; j < 9; j++ )
					printf("%d",map[i][j]+1);
				putchar('\n');
			}
		}
	}
	return 0;
}



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值