Usaco Training [2.1] The Castle 搜索
题目的输出的4个信息
前两个很容易,dfs,bfs都可以,图怎么建都可以
后两个在搜索的时候记录belong[i][j]和已有的size即可
代码应该比不少题解清晰吧
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define rep(i, a, b) for (int i = a; i <= b; ++i) const int N = ; int m, n, a[N][N], bel[N][N], siz[N * N], cnt, mx; int b[N][N][], dir[][] = {{, -}, {-, }, {, }, {, }}; bool vis[N][N]; void dfs(int x, int y) {
if (!vis[x][y] && x > && x <= m && y > && y <= n) {
siz[cnt]++;
vis[x][y] = ;
bel[x][y] = cnt;
rep(i, , ) if (!b[x][y][i]) {
dfs(x + dir[i][], y + dir[i][]);
}
}
} int main() {
scanf("%d%d", &n, &m); rep(i, , m) rep(j, , n) {
scanf("%d", &a[i][j]);
int t = a[i][j];
b[i][j][] = (t % > ); t -= t % ;
b[i][j][] = (t % > ); t -= t % ;
b[i][j][] = (t % > ); t -= t % ;
b[i][j][] = (t % > );
} rep(i, , m) rep(j, , n) if (!vis[i][j]) {
++cnt;
dfs(i, j);
mx = max(mx, siz[cnt]);
} printf("%d\n%d\n", cnt, mx); int dx, dy; char ch;
rep(j, , n) for(int i = m; i >= ; --i) rep(k, , ) {
if (bel[i][j] != bel[i + dir[k][]][j + dir[k][]]) {
if (siz[bel[i][j]] + siz[bel[i + dir[k][]][j + dir[k][]]] > mx) {
mx = siz[bel[i][j]] + siz[bel[i + dir[k][]][j + dir[k][]]];
if (k == ) dx = i + dir[k][], dy = j + dir[k][], ch = 'E';
else if (k == ) dx = i, dy = j, ch = 'N';
else if (k == ) dx = i, dy = j, ch = 'E';
else dx = i + dir[k][], dy = j + dir[k][], ch = 'N';
}
}
}
printf("%d\n%d %d %c\n", mx, dx, dy, ch);
return ;
}
Usaco Training [2.1] The Castle 搜索的更多相关文章
- 关于USACO Training
做了这么久的题目,突然发现最经典的 USACO Training 还没有做过?加速水一遍吧!我会把题解放在上面的.
- USACO Training Section 1.1 坏掉的项链Broken Necklace
题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...
- USACO Training Section 1.1 贪婪的送礼者Greedy Gift Givers
P1201 [USACO1.1]贪婪的送礼者Greedy Gift Givers 题目描述 对于一群(NP个)要互送礼物的朋友,GY要确定每个人送出的钱比收到的多多少.在这一个问题中,每个人都准备了一 ...
- USACO Training Section 1.1 Your Ride Is Here
题目描述 众所周知,在每一个彗星后都有一只UFO.这些UFO时常来收集地球上的忠诚支持者.不幸的是,他们的飞碟每次出行都只能带上一组支持者.因此,他们要用一种聪明的方案让这些小组提前知道谁会被彗星带走 ...
- USACO Training Section 1.2 双重回文数 Dual Palindrom
题目描述 如果一个数从左往右读和从右往左读都是一样,那么这个数就叫做"回文数".例如,12321就是一个回文数,而77778就不是.当然,回文数的首和尾都应是非零的,因此0220就 ...
- [USACO Section 2.1]城堡 The Castle (搜索)
题目链接 Solution 比较恶心的搜索,思路很简单,直接广搜找联通块即可. 但是细节很多,要注意的地方很多.所以直接看代码吧... Code #include<bits/stdc++.h&g ...
- Luogu USACO Training 刷水记录
开个坑记录一下刷USACO的Training的记录 可能会随时弃坑 只有代码和做法简述 可能没有做法简述 [USACO1.1]你的飞碟在这儿Your Ride Is He… 模拟,细节已忘 #incl ...
- USACO Training Section 1.1 题解(共4题)
第一题 题目传送门:你的飞碟在这儿 分析 水题一道,输入两个字符串,将它们转换为数字并同时相乘,然后判断一下它们是不是对于47同余就可以了. 代码 #include<bits/stdc++.h& ...
- USACO Section 2.1 The Castle 解题报告
题目 题目描述 有一个城堡,城堡中有若干个房间,房间与房间之间用墙来进行分隔.现在我们需要统计这个城堡有多少个房间,并且还要找出最大的房间的面积是多少(一个单元格就代表一个单元面积).城堡的主人现在想 ...
随机推荐
- Codeforces Gym100623J:Just Too Lucky(数位DP)
http://codeforces.com/gym/100623/attachments 题意:问1到n里面有多少个数满足:本身被其各个数位加起来的和整除.例如120 % 3 == 0,111 % 3 ...
- redis RDB 和AOF
参考文献 Redis源码学习-AOF数据持久化原理分析(0) Redis源码学习-AOF数据持久化原理分析(1) Redis · 特性分析 · AOF Rewrite 分析 深入剖析 redis AO ...
- 《C#并发编程经典实例》学习笔记—2.7 避免上下文延续
避免上下文延续 在默认情况下,一个 async 方法在被 await 调用后恢复运行时,会在原来的上下文中运行. 为了避免在上下文中恢复运行,可让 await 调用 ConfigureAwait 方法 ...
- Anemic Model
In object-oriented programming, and especially in Domain-Driven Design, objects are said to be anemi ...
- Django中使用JS通过DataTable实现表格前端分页,每页显示页数,搜索等功能
Django架构中自带了后端分页的技术,通过Paginator进行分页,前端点击按钮提交后台进行页面切换. 优缺点:后端分页对于数据量大的场景有其优势,但页面切换比较慢. 后端分页python3代码如 ...
- 17.Linux命令
1.网络配置 setup 配置 ifup eth0 启动网卡 文件保存在 /etc/sysconfig/network-scripts/ifcfg-eth0,修改ifcfg-eth0配 ...
- Zimg—轻量级图片服务器搭建利器
在一个互联网应用中,图片扮演着越来越重要的角色.有稳定的可扩展的图片存储服务器就显得尤为的重要,云厂商们提供了便利的图片存储服务,花钱就可以解决了.这里简单介绍一个开源的一个分布式图片存储服务器--z ...
- mongon库加上权限认证后,java程序连接异常
现象: linux库中mongo库,用超级管理员添加了一个超级管理员,并加了认证. 通过spring等相关的配置文件获取Mongo数据库连接,抛出异常,如下: Caused by: org.sprin ...
- 使用MyBatis在控制台动态打印执行的sql语句
使用MyBatis进行数据库操作的时候,sql语句都是写在相应的mapper文件中,参数也是使用占位符取值表示的,mapper文件中看不到实时执行的完整sql,有时候sql语句错误或者参数类型不对的时 ...
- java算法题每日一练01,java入门简单算法题小练
1.给数组做反序 public class Ak01 { public static void main(String[] args) { int[] a = new int[]{22,48,41,2 ...