POJ2676Sudoku
http://poj.org/problem?id=2676
题意 : 这个是我最喜欢玩的数独了,就是一个9乘9的宫格,填上1到9九个数字,每行每列每个宫格之内不能有重复的数字,给出的九宫格中,0是待填的数字,其他数字是已经填好的,若是无法按要求填出来,就输出原来的九宫格;
思路 : DFS,深搜递归一下,设三个标记数组,标记一下每行的,每列的,每个宫格的,如果这个数字出现了,就标记了就行,我代码里写的是标记数组row[ i ][ j ],代表的是第 i 行的 j 已经出现了,col[ i ][ j ]代表的是第 i 行的 j 数组存在,map[ i ][ j ]宫格 i 的 j 这个数字存在,而宫格的话大家可以自己想一下,如果一个位置的行和列是x,y,那么他所在的九宫格就应该是3*((x-1)/3)+(y-1)/3+1,但如果你往里输入的九宫格下标是从0开始的话,这个就要变成x/3*3+y/3,我也试过,但是从0开始存一直都是错的,后来就改为从一开始存了
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
int row[][],col[][],map[][];//行列宫格的标记数组
int Sudoku[][];
int flag ;//标记变量
int DFS(int x,int y)
{
if(x == )
{
for(int i = ; i <= ; i++)
{
for(int j = ; j <= ; j++)
printf("%d",Sudoku[i][j]);
printf("\n");
}
return ;
}
flag = ;
if(Sudoku[x][y])//该位置原本是有数字的
{
if(y == )
flag = DFS(x+,);
else
flag = DFS(x,y+);
if(flag)
return ;
else
return ;
}
else
{
for(int i = ; i <= ; i++)
if(!row[x][i] && !col[y][i] && !map[*((x-)/)+(y-)/+][i])//如果行列宫格都没有这个数字
{
Sudoku[x][y] = i;//就填上这个数字,然后下边的行列宫格都标记为已填此数字
row[x][i]= ;
col[y][i]= ;
map[*((x-)/)+(y-)/+][i] = ;
if(y == )
flag=DFS(x+,);
else
flag=DFS(x,y+);
if(!flag)//如果没找到合适的,就全部返回原值
{
Sudoku[x][y]=;
row[x][i] = ;
col[y][i]= ;
map[*((x-)/)+(y-)/+][i]=;
}
else
return ;
}
}
return ;
}
void Init()
{
memset(row,,sizeof(row));
memset(col,,sizeof(col));
memset(map,,sizeof(map));
}
int main()
{
int i,j,n;
scanf("%d",&n);
for(int s = ; s < n ; s++)
{
Init();
for(i = ; i <= ; i++)
for(j = ; j <= ; j++)
{
scanf("%1d",&Sudoku[i][j]);
if(Sudoku[i][j])
{
row[i][Sudoku[i][j]] = ;
col[j][Sudoku[i][j]] = ;
map[*((i-)/)+(j-)/+][Sudoku[i][j]] = ;
}
}
DFS(,);
}
return ;
}
POJ2676Sudoku的更多相关文章
- POJ2676Sudoku(类似于八皇后)
Sudoku Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 16444 Accepted: 8035 Special ...
- POJ2676-Sudoku(数独)
想了好久没想到好的解决办法,参考了 http://user.qzone.qq.com/289065406/blog/1303713313 大致题意: 九宫格问题,也有人叫数独问题 把一个9行9列的网格 ...
- 【基础搜索】poj-2676-Sudoku(数独)--求补全九宫格的一种合理方案
数独 时限:2000 MS 内存限制:65536K 提交材料共计: 22682 接受: 10675 特别法官 描述 数独是一个非常简单的任务.一个9行9列的正方形表被分成9个较小的3x ...
- HDU 1426 Sudoku Killer【DFS 数独】
自从2006年3月10日至11日的首届数独世界锦标赛以后,数独这项游戏越来越受到人们的喜爱和重视. 据说,在2008北京奥运会上,会将数独列为一个单独的项目进行比赛,冠军将有可能获得的一份巨大的奖品— ...
随机推荐
- 探索VS中C++多态实现原理
引言 最近把<深度探索c++对象模型>读了几遍,收获甚大.明白了很多以前知其然却不知其所以然的姿势.比如构造函数与拷贝构造函数什么时候被编译器合成,虚函数.实例函数.类函数的区别等等.在此 ...
- Object-C编译的Protobuf
因工作需要,要编译Object-C可用的Protocbuf,开始查资料, http://www.cnblogs.com/uniy/archive/2011/12/21/2296405.html 结果执 ...
- asp.net2.0 国际化
公司业务需要在国外开展了, 因此以前的系统要做多国语言了, 从网上搜集了好多资料, 最后选择了一个比较简单的方案 1. 打开vs2005, 新建网站, 首先在配置文件中添加配置: <syste ...
- 版权控制之zend guard 6.0使用教程
zend guard6.0使用教程.doc 一.准备工具 1. ZendGuard-6_0_0 下载地址:http://www.zend.com/en/products/guard/downloads ...
- jquery.tmpl.min.js--前端实现模版--数据绑定--详解
动态请求数据来更新页面是现在非常常用的方法,比如博客评论的分页动态加载,微博的滚动加载和定时请求加载等. 这些情况下,动态请求返回的数据一般不是已拼好的 HTML 就是 JSON 或 XML,总之不在 ...
- 封装getElementsByClassName
function getElementsByClassName(oEle,sClass,sEle){ if(oEle.getElementsByClassName){ return oEle.getE ...
- 扩展 delphi 线程 使之传递参数.
新delphi的线程TThread有了CreateAnonymousThread方法,如果再为它加一个可传递的参数不就更好了吗?代码如下: TAnonymousThreadX<T> = c ...
- Oracle内存管理理论篇二
目标 了解oracle内存管理方式 掌握ASMM管理方式 掌握AMM管理方式 监控内存使用 学习一个知识点时,最好先了解其历史.ORACLE近期的版本都对内存管理做了简化,从9i通过PGA_AGGRE ...
- xv6实验环境搭建
安装bochs 因为要运行的是xv6,所以不能直接使用 apt-get 直接获取软件.apt-get获取到的软件不支持SMP (Symmetric Multi-Processing).因此,需要下载源 ...
- adbd cannot run as root in production builds
首先必须保证手机已经root过,可以通过以下验证: $ adb shell root@dior:/ $ su root@dior:/ # 1 2 3 执行命令后,$ 变为 # 即 root 成功 但是 ...