POJ 3074 Sudoku (Dacing Links)
推荐一个写数独很好的博客:http://www.cnblogs.com/grenet/p/3163550.html
主要是把九宫格里的元素换到矩阵里面再求解dancing links
网上找的一模版
#include<cstdio>
#include<cstring>
#define MAXM 10
#define MAXL 324
#define MAXN 240000
#define INF 0x7FFFFFFF
char sd[MAXM][MAXM];
int L[MAXN], R[MAXN], U[MAXN], D[MAXN], H[MAXN];
int size, C[MAXN], S[MAXN], X[MAXN], Q[MAXN], vis[MAXL * ];
bool Read()
{
int i, j;
for (i = ; i < MAXM; i++)
{
for (j = ; j < MAXM; j++)
{
scanf(" %c", &sd[i][j]);
if (sd[i][j] == 'e')
return false;
}
}
return true;
}
void Init()
{
int i;
for (i = ; i <= MAXL; i++)
{
L[i + ] = i;
R[i] = i + ;
U[i] = D[i] = i;
S[i] = ;
}
R[MAXL] = ;
size = MAXL + ;
}
void Remove(int c)
{
int i, j;
L[R[c]] = L[c];
R[L[c]] = R[c];
for (i = D[c]; i != c; i = D[i])
{
for (j = R[i]; j != i; j = R[j])
{
U[D[j]] = U[j];
D[U[j]] = D[j];
S[C[j]]--;
}
}
}
void Resume(int c)
{
int i, j;
L[R[c]] = c;
R[L[c]] = c;
for (i = D[c]; i != c; i = D[i])
{
for (j = R[i]; j != i; j = R[j])
{
U[D[j]] = j;
D[U[j]] = j;
S[C[j]]++;
}
}
}
inline void Link(int r, int c)
{
D[size] = D[c];
U[size] = c;
U[D[c]] = size;
D[c] = size;
if (H[r] < )
H[r] = L[size] = R[size] = size;
else
{
L[size] = H[r];
R[size] = R[H[r]];
L[R[H[r]]] = size;
R[H[r]] = size;
}
S[c]++;
X[size] = r;
C[size++] = c;
}
bool Dance(int now)
{
int i, j, c, temp;
if (R[] == )
return true;
for (temp = INF,i = R[]; i; i = R[i])
{
if (S[i] < temp)
{
temp = S[i];
c = i;
}
}
Remove(c);
for (i = D[c]; i != c; i = D[i])
{
vis[X[i]] = true;
for (j = R[i]; j != i; j = R[j])
Remove(C[j]);
if (Dance(now + ))
return true;
for (j = L[i]; j != i; j = L[j])
Resume(C[j]);
vis[X[i]] = false;
}
Resume(c);
return false;
}
int main()
{
int i, j, k, r;
while (Read())
{
Init();
for (r = , i = ; i < MAXM; i++)
{
for (j = ; j < MAXM; j++)
{
if (sd[i][j] == '.')
{
for (k = ; k < MAXM; k++)
{
H[++r] = -;
Q[r] = k;
Link(r, (i - ) * + k);
Link(r, + (j - ) * + k);
Link(r, + ((i - ) / * + (j - ) / ) * + k);
Link(r, + (i - ) * + j);
}
}
else
{
H[++r] = -;
k = sd[i][j] - '';
Q[r] = k;
Link(r, (i - ) * + k);
Link(r, + (j - ) * + k);
Link(r, + ((i - ) / * + (j - ) / ) * + k);
Link(r, + (i - ) * + j);
}
}
}
memset(vis, false, sizeof(vis));
Dance();
for (i = ; i <= r; i++)
{
if (vis[i])
printf("%d", Q[i]);
}
putchar('\n');
}
return ;
}
POJ 3074 Sudoku (Dacing Links)的更多相关文章
- poj 3074 Sudoku(Dancing Links)
Sudoku Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8152 Accepted: 2862 Descriptio ...
- POJ 3074 Sudoku (DLX)
Sudoku Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit Statu ...
- POJ 3074 Sudoku (Dancing Links)
传送门:http://poj.org/problem?id=3074 DLX 数独的9*9的模板题. 具体建模详见下面这篇论文.其中9*9的数独怎么转化到精确覆盖问题,以及相关矩阵行列的定义都在下文中 ...
- POJ 3074 Sudoku DLX精确覆盖
DLX精确覆盖.....模版题 Sudoku Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8336 Accepted: ...
- POJ 3076 Sudoku (dancing links)
题目大意: 16*16的数独. 思路分析: 多说无益. 想说的就是dancing links 的行是依照 第一行第一列填 1 第一行第二列填 2 -- 第一行第十五列填15 第一行第二列填 1 -- ...
- (简单) POJ 3074 Sudoku, DLX+精确覆盖。
Description In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller 3 × 3 subgr ...
- POJ - 3074 Sudoku (搜索)剪枝+位运算优化
In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller 3 × 3 subgrids. For exa ...
- POJ 3074 Sudoku(算竞进阶习题)
二进制优化+dfs 话说这题数据中真的丧心病狂..不加inline还过不去.. 因为不会DLX只好用二进制来优化了...万万没想到还是低空飘过 我们在行.列.格分别用一个9位二进制常数来记录什么数能放 ...
- 搜索(DLX): POJ 3074 3076 Sudoku
POJ 3074 : Description In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller ...
随机推荐
- OpenJudge 2815 城堡问题 / Poj 1164 The Castle
1.链接地址: http://bailian.openjudge.cn/practice/2815/ http://poj.org/problem?id=1164 2.题目: 总时间限制: 1000m ...
- JQuery上传插件Uploadify
一:官网 http://www.uploadify.com/ 二:引用 <link href="plug-in/uploadify3.2.1/uploadify.css" r ...
- MFC 简单输出EXCEL - (OLE)
三图胜千言: 就是酱紫: //打印领料表 void CKnifeDlgDlg::PrintCurUsedTabel(int order) { // TODO: Add your command han ...
- html标签data大写获取不到值:只能小写+横杠命名
html标签data大写获取不到值:只能小写+横杠命名 例如: <i class="glyphicon glyphicon-question-sign" data-tip-t ...
- linux 下C语言编程库文件处理与Makefile编写
做开发快3年了,在linux下编译安装软件算是家常便饭了.就拿gcc来说,都有不下10次了,可基本每次都会碰到些奇奇怪怪的问题.看来还是像vs.codeblocks这样的ide把人弄蠢了.便下定决心一 ...
- php 定时执行任务
之于是否控制,可以做到的,应借用第三个条件: config.php <?phpreturn 1;?> cron.phpignore_user_abort();//关掉浏览器,PHP脚本也可 ...
- STM32库函数实现方法
一.概述 1.调用STM32库函数配置与直接配置寄存器 ① 直接配置寄存器 使用过51单片机的朋友都知道为了将IO口配置成某种特殊功能或者配置中断控制,我们先将需要如下步骤: 根据需要配置功能计算值- ...
- (00)Java编程思想开篇立言。
从今天开始,在相当长的时间中我在看Java编程思想.也把这个博客作为开始.这就是一个读书的笔记.
- 第 11 章 桥梁模式【Bridge Pattern】
以下内容出自:<<24种设计模式介绍与6大设计原则>> 今天我要说说我自己,梦想中的我自己,我身价过亿,有两个大公司,一个是房地产公司,一个是服装制造业,这两个公司都很赚钱,天 ...
- The state of Web Components
Web Components have been on developers’ radars for quite some time now. They were first introduced b ...