【HDOJ】2780 Su-Su-Sudoku
模拟+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的更多相关文章
- 【HDOJ】3909 Sudoku
DLX的应用,基本题,注意maxnode开大点儿. /* 3909 */ #include <iostream> #include <string> #include < ...
- 【HDOJ】4729 An Easy Problem for Elfness
其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...
- 【HDOJ】【3506】Monkey Party
DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...
- 【HDOJ】【3516】Tree Construction
DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...
- 【HDOJ】【3480】Division
DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...
- 【HDOJ】【2829】Lawrence
DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...
- 【HDOJ】【3415】Max Sum of Max-K-sub-sequence
DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...
- 【HDOJ】【3530】Subsequence
DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...
- 【HDOJ】【3068】最长回文
Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...
随机推荐
- RHEL7单独安装图形X11
RHEL7 默认是最小化安装(Minimal Install),没有图形界面,我们应该选择Server with GUI.若已错过此步骤,我们采用以下方式补充安装GUI界面. # yum group ...
- python 函数初识和文件操作
文件操作 打开文件:文件句柄 = open('文件路径', '模式') 打开文件的模式 w #以写的方式打开 (不可读,不存在则创建,存在则删除内容) a #以追加的模式打开(可读, 不存在则创建 ...
- PHP提高编程效率的方法,你知道多少呢?
PHP语言是最WEB的计算机语言,而且也是应用最广泛的语言,那么PHP对编程的影响有多大呢?下面可以去了解一下. 用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜 ...
- SVN服务器的搭建 分类: 网络 2014-11-27 01:18 204人阅读 评论(4) 收藏
一.首先来下载和安装SVN服务器 现在Subversion已经迁移到apache网站上了,下载地址: http://subversion.apache.org/packages.html 这是二进制文 ...
- Asp.net: WebForm基础上构建Mvc的方法
添加引用: System.Web.Routing System.Web.Abstractions System.Web.Mvc 添加文件夹: Controllers, Views, Views / ...
- C# -abstract, override, virtual, new
new声明的方法,当使用子类的类型来调用的时候,它会运行子类的函数,而如果类型是基类的话,被隐藏的基类函数会被调用. 而子类中函数使用override的时候,则当使用子类的类型来调用的是,它会运行子 ...
- mvc5 + ef6 + autofac搭建项目(四)
在列表页面,点击新增,弹出窗口实现视屏上传,这里存在一个问题,就是大文件上传的问题,iis出于安全问题,有限制,当然这不是大问题,解决也很容易: 见截图: 请忽略视屏文件,看得懂的请装作不懂. 源码 ...
- Oracle 11g-R2 SQL Developer连接MSSQL2008
操作系统环境:WINDOWS8.1 工具: Oracle 11g-R2 SQL Developer 网络资源:http://sourceforge.net/project/showfiles.php ...
- Java SE Java EE Java ME 的区别
Java SE(Java Platform,Standard Edition) Java SE 以前称为 J2SE.它允许开发和部署在桌面.服务器.嵌入式环境和实时环境中使用的 Java 应用程序.J ...
- 集成支付宝报一堆warning: (arm64) /Users/scmbuild/workspace/standard-pay/.....警告问题解决办法亲测可行!