http://poj.org/problem?id=2676

深搜的题目。

题意呢就是一个数独的游戏,应该都知道规则。

思路:我的思路很简单,就是用数组来判断某个数字是否可以使用,而每一个数字都由三个条件来限制它,分别是行和列,和其所在的9宫格里面,是不能有重复的。

如果有重复的,则不能使用,甚至都不能尝试。

代码写的也比较渣。还有这个题的数据应该不深,从0,0搜和从8,8开始搜,时间差距非常大,我的从0,0开始是1200Ms,从8,8是16Ms.

这是数据的问题。

 #include <stdio.h>
#include <string.h> int sodu[][],flog; char a[][]; bool h[][],s[][],cube[][]; //h代表行,s代表列,cube代表数字所在的的是哪一个9宫格。 int jud(int x) //用来判断数字是在哪一个9宫格,我的分区是按从0 1 2/3 4 5/6 7 8来分的。
{
if(x>=&&x<) return ;
if(x>=) return ;
return ;
} void bfs(int x,int y)
{
for(int q=;q>=;q--) //这个是来判断是否搜索成功。
{
flog=;
for(int p=;p>=;p--)
{
if(sodu[q][p]==) {flog=;break;}
if(flog&&p==&&q==) flog=;
}
if(flog==) break;
}
for(int i=;i>=&&flog;i--)
for(int j=;j>=;j--)
{
if(sodu[i][j]==)
{
for(int k=;k<;k++)
{
if(h[i][k]&&s[j][k]&&cube[j/+jud(i)][k])
{
sodu[i][j]=k;
h[i][k]=false;
s[j][k]=false;
cube[j/+jud(i)][k]=false;
bfs(,);
if(flog==)return;
h[i][k]=true;
s[j][k]=true;
cube[j/+jud(i)][k]=true;
}
}
sodu[i][j]=; //这里记得要归0,不然回溯的时候,下一次不会再这个数值。
if(sodu[i][j]==)return;
}
}
} int main()
{
int n;
scanf("%d",&n);
while(n--)
{
for(int i=;i<;i++)
scanf("%s",a[i]);
for(int i=;i<;i++)
for(int j=;j<;j++)
sodu[i][j]=a[i][j]-'';
memset(h,true,sizeof(h));
memset(s,true,sizeof(s));
memset(cube,true,sizeof(cube));
for(int i=;i<;i++)
for(int j=;j<;j++)
{
if(sodu[i][j]!=)
{
h[i][sodu[i][j]]=false;
s[j][sodu[i][j]]=false;
cube[j/+jud(i)][sodu[i][j]]=false;
}
}
flog=;
bfs(,);
for(int i=;i<;i++)
{
for(int j=;j<;j++)
printf("%d",sodu[i][j]);
printf("\n");
} }
return ;
}

POJ 2676的更多相关文章

  1. ACM : POJ 2676 SudoKu DFS - 数独

    SudoKu Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu POJ 2676 Descr ...

  2. 深搜+回溯 POJ 2676 Sudoku

    POJ 2676 Sudoku Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 17627   Accepted: 8538 ...

  3. 随手练——POJ - 2676 数独 (回溯法)

    POJ - 2676 : http://poj.org/problem?id=2676: 解题思想 (大力出奇迹): 1. 依次在空格里面填上“1~9”,并检查这个数字是否合法(其所在的行.列,以及3 ...

  4. 搜索 --- 数独求解 POJ 2676 Sudoku

    Sudoku Problem's Link:   http://poj.org/problem?id=2676 Mean: 略 analyse: 记录所有空位置,判断当前空位置是否可以填某个数,然后直 ...

  5. poj 2676 Sudoku ( dfs )

    dfs 用的还是不行啊,做题还是得看别人的博客!!! 题目:http://poj.org/problem?id=2676 题意:把一个9行9列的网格,再细分为9个3*3的子网格,要求每行.每列.每个子 ...

  6. POJ 2676 Sudoku (数独 DFS)

      Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 14368   Accepted: 7102   Special Judg ...

  7. POJ 2676 - Sudoku - [蓝桥杯 数独][DFS]

    题目链接:http://poj.org/problem?id=2676 Time Limit: 2000MS Memory Limit: 65536K Description Sudoku is a ...

  8. 【POJ 2676】 Sudoku

    [题目链接] http://poj.org/problem?id=2676 [算法] 深度优先搜索 [代码] #include <algorithm> #include <bitse ...

  9. POJ 2676/2918 数独(dfs)

    思路:记录每行每列每一个宫已经出现的数字就可以.数据比較弱 另外POJ 3074 3076 必须用剪枝策略.但实现较麻烦,还是以后学了DLX再来做吧 //Accepted 160K 0MS #incl ...

随机推荐

  1. Orchard源码分析(6):Shell相关

    概述在Orchard中,提出子站点(Tenant)的概念,目的是为了增加站点密度,即一个应用程序域可以有多个子站点. Shell是子站点(Tenant)级的单例,换句话说Shell代表了子站点.对比来 ...

  2. python mysql

    mysql Linux 安装mysql: apt-get install mysql-server 安装python-mysql模块:apt-get install python-mysqldb Wi ...

  3. MySQL关键字(保留字)列表

    在使用MySQL的时候,一般尽量避免用关键字作为表名,如使用关键字做表名,需要按标准写法给SQL语句加[](或是“)区分字段名和表名. 下面列出MySQL所有关键字,希望给使用MySQL的朋友提供一些 ...

  4. base64 加密

    Base64 参考网站:http://zh.wikipedia.org/wiki/Base64 简介 是网络上使用最广泛的编码系统,能够将任何二进制数据,转换成只有 65 个字符组成的文本文件 a~z ...

  5. Swing杂记——Swing中引入Android的NinePatch技术,让Swing拥有Android的外观定制能力

    [摘要] 本文诣在展示如何在Swing中引入 NinePatch技术(早期有文章里中文译作九格图,暂且这么叫吧^_^,但此术非传统移动手机上的功能布局——九格图哦). [准备篇] Q:何为 NineP ...

  6. POJ 3744 Scout YYF I

    分段的概率DP+矩阵快速幂                        Scout YYF I Time Limit: 1000MS   Memory Limit: 65536K Total Sub ...

  7. Eclipse经常报Unhandled event loop exception的原因

    在公司的电脑上,Eclipse经常报Unhandled event loop exception 错误,非常频繁,通过搜索发现是因为电脑上安装了百度杀毒导致的.... 无语 另外 teamviewer ...

  8. 微信小程序开放公测了 晚上又可以通宵搞代码了

    就在刚刚22:15分,微信公众平台的服务号发来好消息说小程序开放公测了,喜大普奔啊!!!码农们晚上又可以通宵搞测试了.之前还猜测16日微信小论坛小程序专场上会公布,没想到提前了那么多天,效率挺高的,而 ...

  9. Swift3.0P1 语法指南——基本操作符

    原档:https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programmi ...

  10. MVC中下拉列表绑定方法

    方法一: 前端 @Html.DropDownListFor(a=>a.acate,ViewBag.CateList as IEnumerable<SelectListItem>) 后 ...