SGU 125.Shtirlits
时间限制:0.25s
空间限制:4M
题意:
有N*N的矩阵(n<=3),对所有i,j<=n有G[i][j]<=9,定义f[i][j]为G[i][j]四周大于它的数的个数(F[i][j]<=4),
现在 给出n和F[i][j],输出一种可形的G。
Sample Input
3
1 2 1
1 2 1
1 1 0
Sample Output
1 2 3
1 4 5
1 6 7
Solution:
观察给出的F矩阵,以样例为例
| 1 | 2 | 1 |
| 1 | 2 | 1 |
| 1 | 1 | 0 |
首先知道
F[3][3]==0,那么G[3][3]一定是最大的,令当前填的数为K(K=N*N)
这时将F[3][3],四周的所有F[i][j]减1,变成
| 1 | 2 | 1 |
| 1 | 2 | 0 |
| 1 | 0 | # |
(#号代表已填)
这样重复上面的步骤,每次做完执行k--
直到发现
| 1 | 2 | 0 |
| 0 | 0 | # |
| # | # | # |
这时对应的G为
| * | * | * |
| * | * | 7 |
| 6 | 8 | 9 |
(*代表还未填)
F出现两个以上接触的0,那么同时填这些接触的0为K
此时F矩阵为
| 0 | 1 | 0 |
| # | # | # |
| # | # | # |
G矩阵为
| * | * | * |
| 5 | 5 | 7 |
| 6 | 8 | 9 |
最后得到G矩阵
| 3 | 3 | 4 |
| 5 | 5 | 7 |
| 6 | 8 | 9 |
这样就得到了一种满足要求的输出
最后总结就是,令k=n*n,对F填一个F[i][j]==0的位置为k,如果有联通的0,将这些为0的位置全部填为K,
再将填了数的位置的四周的F[i][j]减一。
如果填完所有0的位置后,G矩阵已经填完那么输出G
G没有填完的话,输出“No Solution”;
参考代码:
#include <iostream>
#include <queue>
#include <cstring>
using namespace std;
struct node {
int x, y;
} p;
int dirx[4] = {0, 0, -1, 1}, diry[4] = {1, -1, 0, 0};
int g[5][5], f[5][5], pd[5][5];
int n, t, k;
queue<node> ql;
void BFS (int x, int y, int k) {
node p;
for (int i = 0; i <= 3; i++) {
p.x = x + dirx[i], p.y = y + diry[i];
if (f[p.x][p.y] == 0) {
g[p.x][p.y] = k, t++;
f[p.x][p.y] = -1, pd[p.x][p.y] = 1;
BFS (p.x, p.y, k);
}
else if (f[p.x][p.y] > 0)
if ( (--f[p.x][p.y]) == 0) ql.push (p);
}
}
int main() {
cin >> n;
memset (f, -1, sizeof f);
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++) {
cin >> f[i][j];
if (f[i][j] == 0) {
p.x = i, p.y = j;
ql.push (p);
}
}
k = n * n;
for (node p; !ql.empty(); ql.pop(), k--) {
p = ql.front();
if (pd[p.x][p.y]) continue;
pd[p.x][p.y] = 1, g[p.x][p.y] = k, f[p.x][p.y] = -1, t++;
BFS (p.x , p.y, k);
}
if (t != n * n) cout << "NO SOLUTION";
else
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++)
cout << g[i][j] << ' ';
cout << endl;
}
return 0;
}
SGU 125.Shtirlits的更多相关文章
- sgu 125 Shtirlits dfs 难度:0
125. Shtirlits time limit per test: 0.25 sec. memory limit per test: 4096 KB There is a checkered fi ...
- SGU 125 Shtirlits 搜索+可行性剪枝
500ms时限406ms水过…… 直接枚举肯定超时,需要剪枝. 枚举每个格子的元素,检查其左上角和正上方格子是否满足条件,若不满足不必再向下搜索. 在 这里 看到一个更好的方法: 枚举每个格子是哪个相 ...
- Shtirlits - SGU 125(搜索)
题目大意:B[i, j]表示周围有多少个比它大的数,能否用B数组构造出一个A数组,如果不能输出“NO SOLUTION”. 分析:数据规模比较小,可以直接暴力枚举每个点的值. 代码如下: #inclu ...
- ACM 暴力搜索题 题目整理
UVa 129 Krypton Factor 注意输出格式,比较坑爹. 每次要进行处理去掉容易的串,统计困难串的个数. #include<iostream> #include<vec ...
- SGU 分类
http://acm.sgu.ru/problemset.php?contest=0&volume=1 101 Domino 欧拉路 102 Coprime 枚举/数学方法 103 Traff ...
- 今日SGU 5.18
SGU 125 题意:给你一个数组b[i][j],表示i,j的四周有多少个数字大于它的,问你能不能构造出一个a矩形 收获:dfs + 剪枝 一行一行的dfs,然后第一行去枚举0-9,下一行判断当前选 ...
- Entity Framework 6 Recipes 2nd Edition(12-5)译 -> 自动删除相关联实体
12-5. 自动删除相关联实体 问题 当一个实体被删除时,你想自动删除它相关联的实体 解决方案 假设你有一个表结构由一个course (科目), course 的classes (课程),以及enro ...
- FineUI(开源版)v4.2.2发布(8年125个版本,官网示例突破300个)!
开源版是 FineUI 的基石,从 2008 年至今已经持续发布了 120 多个版本,拥有会员 15,000 多位,捐赠会员达到 1,200 多位. FineUI(开源版)v4.2.2 是 8 年 ...
- 每周一书-编写高质量代码:改善C程序代码的125个建议
首先说明,本周活动有效时间为2016年8月28日到2016年9月4日.本周为大家送出的书是由机械工业出版社出版,马伟编著的<编写高质量代码:改善C程序代码的125个建议>. 编辑推荐 10 ...
随机推荐
- 纯css切换左侧菜单
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Linux Shell编程(28)——进程替换
进程替换与命令替换很相似. 命令替换把一个命令的结果赋给一个变量,例如 dir_contents=`ls -al`或xref=$. 进程替换则是把一个进程的输出回馈给另一个进程 (换句话说,它把一个命 ...
- dotfuscator使用方法
dotfuscator如何对.net程序进行混淆保护对于程序代码的保护,网上有很多资料,有的说混淆,有的说加密,我比较支持混淆的方法,这样可以让反编译劳工,头晕一阵子,哈哈开玩笑.对于加密如果不是不得 ...
- [cocos2dx 3.0 + xcode]疑难点记录
1: 新项目创建 1.下载最新Python,安装 2.解压引擎包 3.运行终端,切换到引擎目录(直接cd拖动文件夹到光标即可得到路径) 4.按照文档例子: $ cd cocos2d-x $ ./set ...
- nyoj 88 汉诺塔(一)【快速幂】
汉诺塔(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 在印度,有这么一个古老的传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针.印度 ...
- JVM分代垃圾回收策略的基础概念
由于不同对象的生命周期不一样,因此在JVM的垃圾回收策略中有分代这一策略.本文介绍了分代策略的目标,如何分代,以及垃圾回收的触发因素. 文章总结了JVM垃圾回收策略为什么要分代,如何分代,以及垃圾回收 ...
- Eclipse下Tomcat常用设置
Eclipse下Tomcat常用设置 1,Eclipse建立Tomcat服务 1.1 新建Server 首先这里是指,jee版的Eclipse.Eclipse是没有像MyEclipse那样集成Tomc ...
- HTTPClient实现java自动登录人人网
参考网址: https://passport.csdn.net/account/login http://www.iteye.com/topic/638206 httpClient http://b ...
- ASP.NET通过http/https的POST方式,发送和接受XML文件内容
本文转载:http://hi.baidu.com/ysyhyt/item/5011ae39ce3cf49fb80c0395 本文参考:http://blog.csdn.net/ououou123456 ...
- JAVA获取随机数
在Java中我们能够使用java.util.Random类来产生一个随机数发生器.它有两种形式的构造函数,各自是Random()和Random(long seed).Random()使用当前时间即Sy ...