模拟+DFS。

 /* 2780 */
#include <cstdio>
#include <cstring>
#include <cstdlib> char map[][];
int visit[][][];
int fn;
int fx[], fy[]; bool dfs(int n) {
if (n == )
return true;
int i = fx[n], j = fy[n], k, r; for (k=; k<=; ++k) {
if (!visit[i][j][k]) {
map[i][j] = k;
visit[i][j][k]++;
for (r=; r<; ++r) {
visit[i][r][k]++;
visit[r][j][k]++;
visit[i/*+k/][j/*+k%][k]++;
}
if (dfs(n-))
return true;
visit[i][j][k]--;
for (r=; r<; ++r) {
visit[i][r][k]--;
visit[r][j][k]--;
visit[i/*+k/][j/*+k%][k]--;
}
}
}
return false;
} bool check() {
int i, j, k;
int x, y, in;
bool f[]; // check row
for (i=; i<; ++i) {
memset(f, false, sizeof(f));
for (j=; j<; ++j) {
if (map[i][j] && f[map[i][j]]) {
return true;
}
f[map[i][j]] = true;
}
} // check line
for (j=; j<; ++j) {
memset(f, false, sizeof(f));
for (j=; j<; ++j) {
if (map[i][j] && f[map[i][j]]) {
return true;
}
f[map[i][j]] = true;
}
} // check sub
for (x=; x<; ++x) {
memset(f, false, sizeof(f));
for (y=; y<; ++y) {
i = x/* + y/;
j = x%* + y%;
if (map[i][j] && f[map[i][j]]) {
return true;
}
f[map[i][j]] = true;
}
} return false;
} int main() {
int t;
int i, j, k;
bool flag; #ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif scanf("%d", &t);
while (t--) {
memset(visit, , sizeof(visit));
fn = ;
for (i=; i<; ++i) {
scanf("%s", map[i]);
for (j=; j<; ++j) {
map[i][j] -= '';
if (map[i][j] == ) {
fx[fn] = i;
fy[fn] = j;
++fn;
} else {
for (k=; k<; ++k) {
visit[i][k][map[i][j]]++;
visit[k][j][map[i][j]]++;
visit[i/*+k/][j/*+k%][map[i][j]]++;
}
}
}
}
if (check()) {
flag = false;
} else {
flag = dfs();
}
if (flag) {
for (i=; i<; ++i) {
for (j=; j<; ++j)
map[i][j] += '';
puts(map[i]);
}
} else {
puts("Could not complete this grid.");
}
if (t)
printf("\n");
} return ;
}

【HDOJ】2780 Su-Su-Sudoku的更多相关文章

  1. 【HDOJ】3909 Sudoku

    DLX的应用,基本题,注意maxnode开大点儿. /* 3909 */ #include <iostream> #include <string> #include < ...

  2. 【HDOJ】4729 An Easy Problem for Elfness

    其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...

  3. 【HDOJ】【3506】Monkey Party

    DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...

  4. 【HDOJ】【3516】Tree Construction

    DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...

  5. 【HDOJ】【3480】Division

    DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...

  6. 【HDOJ】【2829】Lawrence

    DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...

  7. 【HDOJ】【3415】Max Sum of Max-K-sub-sequence

    DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...

  8. 【HDOJ】【3530】Subsequence

    DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...

  9. 【HDOJ】【3068】最长回文

    Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...

随机推荐

  1. 科讯CMS V9标签清单

    全新整理V9标签清单 ====================网站通用标签============== {$GetSiteTitle} 显示网站标题 {$GetSiteName} 显示网站名称 {$G ...

  2. JavaScript的DOM操作(二)

    一:window.history对象 历史记录,通过历史记录可以操作页面前进或者后退 window.history.back();后退 window.history.forward();前进 wind ...

  3. 在eclipse中部署发布web项目 和 更改eclipseweb项目发布的路径

    我的工作空间:d:workspaceweb项目名称:xxx在eclipse配置完tomcat后,发布到的路径是 d:\workspace\.metadata\.plugins\org.eclipse. ...

  4. centos7 安装php5.6.0 、nginx1.7.4、phpssdbadmin

    1 创建用户.网站目录和下载相关的安装包 groupadd www #添加www组 创建目录/data/www/ chown www:www /data/www/ -R #设置目录所有者 chmod ...

  5. Attribute 特性

    转载   不错   摘要:纠结地说,这应该算是一篇关于Attribute 的笔记,其中的一些思路和代码借鉴了他人的文笔(见本文底部链接).但是,由于此文对Attribute 的讲解实在是叫好(自夸一下 ...

  6. [XML] C#ResourceManagerWrapper帮助类 (转载)

    点击下载 ResourceManagerWrapper.rar /// <summary> /// 类说明:ResourceManagerWrapper /// 编 码 人:苏飞 /// ...

  7. c语言学习之基础知识点介绍(七):循环结构

    本节主要介绍循环结构 一.while循环 /* 语法: while(表达式){ //循环体; } 注意:循环变量.循环条件和循环控制语句三者缺一不可. 例如: */ ; //循环变量 ){ //循环条 ...

  8. 数据库性能高校:CPU使用过高(上)

    CPU使用率过高问题很容易被发现,但是诊断却不是很容易.CPU使用过高很多时候会成为其它问题的替罪羊,所以在确认和故障诊断时要抽丝剥茧. 调查CPU压力 三个主要的工具:性能监视器,SQLTrace, ...

  9. SQL输出矩阵

    数据库环境:SQL SERVER2008R2 需求:用SQL实现如下2个图中的矩阵.            图1和图2都是行列转换的另一个变形,下面直接贴上SQL脚本. 图1的SQL实现 /*利用系统 ...

  10. CSS-id选择器-类选择器-属性选择器

    Css基础 CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明. 选择器通常是您需要改变样式的 HTML 元素. 每条声明由一个属性和一个值组成. 每个属性有一个值.属性和值被冒号分开. 下 ...