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 ...
随机推荐
- [UIKit学习]00.关于前置知识(storyboard,UIViewController,类扩展,项目属性)
storyboard文件的认识 用来描述软件界面 默认情况下,程序一启动就会加载Main.storyboard 加载storyboard时,会首先创建和显示箭头所指的控制器界面 IBAction和IB ...
- Opengl4.5 中文手册—F
索引 A B C D E F G H I J K L M N O P Q ...
- java基础解析系列(七)---ThreadLocal原理分析
java基础解析系列(七)---ThreadLocal原理分析 目录 java基础解析系列(一)---String.StringBuffer.StringBuilder java基础解析系列(二)-- ...
- 【充分利用你的Azure】将Azure用作云计算平台(1)
本文将围绕几个步骤来讲. 因为本人是MSP,微软送了150刀的额度给我随便使用.这篇文章是要讲将Azure用作云计算平台,对于我来说,我是做机器学习的,那么Azure就要有机器学习的平台. 本文的目的 ...
- Elasticsearch 数据搜索
ES即简单又复杂,你可以快速的实现全文检索,又需要了解复杂的REST API.本篇就通过一些简单的搜索命令,帮助你理解ES的相关应用.虽然不能让你理解ES的原理设计,但是可以帮助你理解ES,探寻更多的 ...
- 基于nginx的虚拟主机的配置
安装pcre tar -xvf pcre-8.32.tar.gz cd pcre-8.32 ./configure make;make install 安装nginx 首先创建一个nginx用户,以n ...
- win7+ ubuntu 双系统
windows +linux双系统组合有多种方式,只要划好分区两者即可共处,本文是为了解决两者在启动时遇到的问题. 第三方启动器(例如grub,grub2,grub4dos等)
- asp.net微软图表控件使用示例
<configuration> <system.webServer> <handlers> <remove name="ChartImageHand ...
- winPcap编程之不用回调方法捕获数据包(五 转)
这一次要分析的实例程序跟上一讲非常类似(“打开适配器并捕获数据包”),略微不同的一点是本次将pcap_loop()函数替换成了pcap_next_ex()函数.本节的重点也就是说一下这两个函数之间的差 ...
- Java爬虫
作为一位Java爬虫的初学者,分享一下自己的心得.所用到的jar包 org.codehaus.jettison.jar jsoup-1.7.3.jar个人认为爬虫的实现机制:获取Docume对象-&g ...