Sudoku Killer
据说,在2008北京奥运会上,会将数独列为一个单独的项目进行比赛,冠军将有可能获得的一份巨大的奖品———HDU免费七日游外加lcy亲笔签名以及同hdu
acm team合影留念的机会。
所以全球人民前仆后继,为了奖品日夜训练茶饭不思。当然也包括初学者linle,不过他太笨了又没有多少耐性,只能做做最最基本的数独题,不过他还是想得到那些奖品,你能帮帮他吗?你只要把答案告诉他就可以,不用教他是怎么做的。
数独游戏的规则是这样的:在一个9x9的方格中,你需要把数字1-9填写到空格当中,并且使方格的每一行和每一列中都包含1-9这九个数字。同时还要保证,空格中用粗线划分成9个3x3的方格也同时包含1-9这九个数字。比如有这样一个题,大家可以仔细观察一下,在这里面每行、每列,以及每个3x3的方格都包含1-9这九个数字。
例题:
Killer" title="Sudoku Killer">
答案:
Killer" title="Sudoku Killer">
的矩阵,同一行相邻的两个元素用一个空格分开。其中1-9代表该位置的已经填好的数,问号(?)表示需要你填的数。
对于每组测试数据保证它有且只有一个解。
3 5 8
1 ? 4
6 7 2
? 3 7
2 4 1
9 ? 5
4 8 6
5 1 9
? 2 3
3 5 8
1 9 4
6 7 2
8 3 7
2 4 1
9 6 5
4 8 6
5 1 9
7 2 3
#include
#include
using namespace std;
const int M=9*9;
const int N=10;
int mapn[N][N];
bool col[N][N],res[N][N],mark[N][N];
int op;
struct node
{
node(int
x=0,int y=0) :x(x),y(y){}
int
x,y;//用来表示需要填的空格的坐标
};
node nod[M];
bool check(int i,int j,int w)
{
if(col[i][w]||res[j][w]||mark[(i/3)*3+j/3][w])
return false;
return true;
}
//void printf()
//{
// for(int
i=0;i<9;i++)
// {
//
for(int j=0;j<9;j++)
//
printf(j?" %d":"%d",mapn[i][j]);
//
printf("%d\n");
// }
bool dfs(int t)
{
int
x=nod[t].x,y=nod[t].y;
if(t==op)
{
//printf();
//cout<<"找到解了"<<endl;
return true;
}
for(int
i=1;i<=9;i++)
{
if(check(x,y,i))
{
//cout<<i<<" ";
col[x][i]=1;
res[y][i]=1;
mark[(x/3)*3+y/3][i]=1;
mapn[x][y]=i;
if(dfs(t+1))
return true;
col[x][i]=0;
res[y][i]=0;
mark[(x/3)*3+y/3][i]=0;
}
}
int main()
{
//freopen("in.txt", "r", stdin);
char
str;
int
ans=0;
while(cin>>str)
{
memset(col,0,sizeof(col));
memset(res,0,sizeof(res));
memset(mark,0,sizeof(mark));
op=0;
if(ans++)
printf("\n");
for(int i=0;i<9;i++)
for(int j=0;j<9;j++)
{
if(i!=0||j!=0)
cin>>str;
if(str>='1'&&str<='9')
{
mapn[i][j]=str-'0';
col[i][mapn[i][j]]=1;
res[j][mapn[i][j]]=1;
mark[(i/3)*3+j/3][mapn[i][j]]=1;
}
else
{
mapn[i][j]=0;
nod[op++]=node(i,j);
}
}
//for(int i=0;i<9;i++)
//{
// for(int
j=0;j<9;j++)
//
printf(j?" %d":"%d",mapn[i][j]);
// printf("\n");
//}
dfs(0);
for(int i=0;i<9;i++)
{
for(int j=0;j<8;j++)
cout<<mapn[i][j]<<" ";
cout<<mapn[i][8]<<endl;
}
}
return
0;
}
Sudoku Killer的更多相关文章
- hdu1426 Sudoku Killer
Sudoku Killer Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total ...
- HDU1426 Sudoku Killer(DFS暴力) 2016-07-24 14:56 65人阅读 评论(0) 收藏
Sudoku Killer Problem Description 自从2006年3月10日至11日的首届数独世界锦标赛以后,数独这项游戏越来越受到人们的喜爱和重视. 据说,在2008北京奥运会上,会 ...
- hdu 1426:Sudoku Killer(DFS深搜,进阶题目,求数独的解)
Sudoku Killer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- HDU 1426 Sudoku Killer(dfs 解数独)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1426 Sudoku Killer Time Limit: 2000/1000 MS (Java/Oth ...
- hdu 1426 Sudoku Killer (dfs)
Sudoku Killer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- Steam 游戏 《Sudoku Universe(数独宇宙)》、《Sudoku Killer(数独杀手)》、《Sudoku Jigsaw(数独拼图)》数字位置解析 ---------C# 数独程序解析(2020年寒假小目标11)
日期:2020.02.11 博客期:151 星期二 今天,准备肝一个 C# 的数独读写工具(汇编语言也在努力学习命令方法中...),这三个游戏我早就买下了,一直放在 Steam 库里积灰,看着它的成就 ...
- P - Sudoku Killer HDU - 1426(dfs + map统计数据)
P - Sudoku Killer HDU - 1426 自从2006年3月10日至11日的首届数独世界锦标赛以后,数独这项游戏越来越受到人们的喜爱和重视. 据说,在2008北京奥运会上,会将数独列为 ...
- hdu Sudoku Killer
简单的dfs,主要就是每个?处填的值是否满足条件的判断.这道题感觉考察的是输出格式的控制. #include"iostream" #include"stdio.h&quo ...
- hdu 1426 Sudoku Killer
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1426 #include<stdio.h> #include<math.h> #in ...
随机推荐
- foreach循环中为什么不要进行remove/add操作
先来看一段代码,摘自阿里巴巴的java开发手册 List<String> a = new ArrayList<String>(); a.add("1"); ...
- 多线程进阶---Thread.join()/CountDownLatch.await() /CyclicBarrier.await()
Thread.join() CountDownLatch.await() CyclicBarrier.await() 三者都是用来控制程序的"流动" 可以让程序"堵塞&q ...
- Message:Unable to locate element 问题解决方法
Python断断续续学了有一段时间了,总感觉不找个小项目练练手心里没底,哪成想出门就遇到"拦路虎",一个脚本刚写完就运行报错,还好做足了心里准备,尝试自行解决. 或许网上有相关解决 ...
- 使用java实现面向对象-File I/O
java.io.File类用于表示文件(目录) File类只用于表示文件(目录)的信息(名称.大小等),不能用于文件内容的访问 RandomAccessFile java提供的对文件内容的访问,既可以 ...
- VB.net DateTimePicker 初始化为空,选择后显示日期
目的:当某记录的日期数据为空的时候,DateTimePicker 不以默认当前时间显示. 优点:避免不规则的时间格式输入:符合平时遇到的时间输入习惯 缺点:设置要代码,没有textbox控件那么方便设 ...
- rem绝对自适应方案
rem css3新增的rem是现在非常受欢迎的单位.看一下MDN上的说明: 这个单位代表根元素的 font-size 大小(例如 <html> 元素的font-size). 使用这个单位可 ...
- linux下c语言的多线程编程
我们在写linux的服务的时候,经常会用到linux的多线程技术以提高程序性能 多线程的一些小知识: 一个应用程序可以启动若干个线程. 线程(Lightweight Process,LWP),是程序执 ...
- python读取命令行参数的方法
1.sys模块 需要模块:sys参数个数:len(sys.argv)脚本名: sys.argv[0]参数1: sys.argv[1]参数2: sys.argv[2] test.p ...
- js根据时间戳倒计时
今天有个需求,要在页面上做当前时间距离下个月1号的倒计时.在网上找了很多案例也试了很多,大部分都是获取本地当前时间,然后设置结束时间进行计算,然后倒计时.但是有几个问题: 1.如果本地时间和服务器时间 ...
- swiper 初始化的两个小坑
1.当swiper loop设为true时,同时你又改变了sliderPerview的值,这时候轮播,按prev按钮到第一个时,会出现空白页: 解决办法:sliderPerview设置为auto,lo ...