洛谷:P1331 海战

题目描述

在一个方形的盘上,放置了固定数量和形状的船只,每只船却不能碰到其它的船。在本题中,我们认为船是方形的,所有的船只都是由图形组成的方形。

求出该棋盘上放置的船只的总数。

输入格式

第一行为两个整数 R 和 C,用空格隔开,分别表示游戏棋盘的行数和列数。

接下来 R 行,每行 C 个字符,为 #.# 表示船只的一部分,. 表示水。

输出格式

一行一个字符串,如果船的位置放得正确(即棋盘上只存在相互之间不能接触的方形,如果两个 # 号上下相邻或左右相邻却分属两艘不同的船只,则称这两艘船相互接触了)。就输出 There are S ships.,S 表示船只的数量。否则输出 Bad placement.

思路

一眼就是标准的Flood Fill算法,这没啥好说的。本题唯一要考虑的点,就是"正方形"这个条件,船的形状组合起来必须是一个正方形,我们考虑增加几个变量来记录在一次DFS当中能够蔓延的上,下左右边界。cnt是蔓延的点的数量,如果最终正方形的面积和cnt不等说明,这个正方形中有位置空缺,也就是船只形状不是正方形,直接输出Bad placement.。

题目给的这个输入样例参考价值不大,这里我补充一个样例。

样例

输入:

复制代码
4 4
#...
.#.#
.##.
.#..

输入:

复制代码
Bad placement.

C++源代码:

复制代码
#include <bits/stdc++.h>
using namespace std;
int n, m, ans;
char a[1003][1003];
int minl, maxr, mint, maxb, cnt;
void dfs(int x,int y) {//如何判断是否是矩形
	if (x < 0 || x >= n || y < 0 || y >= m) {//越界
		return;
	}
	if (a[x][y] == '.') {
		return;
	}
	a[x][y] = '.';
	++cnt;
	minl = min(minl, y);
	maxr = max(maxr, y);
	mint = min(mint, x);
	maxb = max(maxb, x);
	dfs(x + 1, y);
	dfs(x - 1, y);
	dfs(x, y + 1);
	dfs(x, y - 1);
}
int main() {//遇到水不会向前 遇到来过的不会向前
	cin >> n >> m;
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++) {
			cin >> a[i][j];
		}
	}
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++) {
			if (a[i][j] == '#') {
				++ans;
				minl = j, maxr = j, mint = i, maxb = i, cnt = 0;
				dfs(i, j);
				if (cnt != (maxr - minl + 1) * (maxb - mint + 1)) {
					printf("Bad placement.");
					return 0;
				}
			}
		}
	}
	printf("There are %d ships.", ans);
	return 0;
}
相关推荐
躲着人群23 分钟前
次短路&&P2865 [USACO06NOV] Roadblocks G题解
c语言·数据结构·c++·算法·dijkstra·次短路
心动啊1211 小时前
支持向量机
算法·机器学习·支持向量机
小欣加油2 小时前
leetcode 1493 删掉一个元素以后全为1的最长子数组
c++·算法·leetcode
蓝风破云3 小时前
C++实现常见的排序算法
数据结构·c++·算法·排序算法·visual studio
艾醒3 小时前
大模型面试题剖析:Pre-Norm与Post-Norm的对比及当代大模型选择Pre-Norm的原因
算法
怀旧,3 小时前
【C++】 9. vector
java·c++·算法
浩浩测试一下4 小时前
06高级语言逻辑结构到汇编语言之逻辑结构转换 for (...; ...; ...)
汇编·数据结构·算法·安全·web安全·网络安全·安全架构
辞--忧5 小时前
K-Means 聚类算法详解与实战指南
算法·kmeans·聚类
尤超宇5 小时前
K 均值聚类(K-Means)演示,通过生成笑脸和爱心两种形状的模拟数据,展示了无监督学习中聚类算法的效果。以下是详细讲解:
算法·均值算法·聚类
qq_479875436 小时前
设置接收超时(SO_RCVTIMEO)
c语言·算法