海战
题目背景
在峰会期间,武装部队得处于高度戒备。警察将监视每一条大街,军队将保卫建筑物,领空将布满了 F-2003 飞机。
此外,巡洋船只和舰队将被派去保护海岸线。不幸的是,因为种种原因,国防海军部仅有很少的几位军官能指挥大型海战。因此,他们培养了一些新海军指挥官。军官们选择了“海战”游戏来帮助他们学习。
题目描述
在一个方形的盘上,放置了固定数量和形状的船只,每只船却不能碰到其它的船。在本题中,我们认为船是方形的,所有的船只都是由图形组成的方形。
求出该棋盘上放置的船只的总数。
输入格式
第一行为两个整数 $R$ 和 $C$,用空格隔开,分别表示游戏棋盘的行数和列数。
接下来 $R$ 行,每行 $C$ 个字符,为 #
或 .
。#
表示船只的一部分,.
表示水。
输出格式
一行一个字符串,如果船的位置放得正确(即棋盘上只存在相互之间不能接触的方形,如果两个 #
号上下相邻或左右相邻却分属两艘不同的船只,则称这两艘船相互接触了)。就输出 There are S ships.
,$S$ 表示船只的数量。否则输出 Bad placement.
。
样例 #1
样例输入 #1
6 8
.....#.#
##.....#
##.....#
.......#
#......#
#..#...#
样例输出 #1
There are 5 ships.
提示
对于 $100\%$ 的数据,$1 \le R,C \le 1000$。
思路:check() 判断是否存在非法船只 因为船的形状必须是矩形
所以在一个2*2的方格中有三个# 即存在非法船只
dfs 连通块 统计船只数量
include[HTML_REMOVED]
using namespace std;
int r,c,ans;
bool st[1010][1010];
char dir[1010][1010];
int dx1[4]={0,0,1,-1},dy1[4]={1,-1,0,0};
int dx2[4]={0,0,1,1},dy2[4]={0,1,0,1};
bool check()
{
for(int i=1;i[HTML_REMOVED]r||ty<1||ty>c||st[tx][ty]) continue;
dfs(tx,ty);
}
}
}
int main()
{
cin>>r>>c;
for(int i=1;i<=r;i)
{
for(int j=1;j<=c;j)
{
cin>>dir[i][j];
}
}
if(!check())
{
cout<<”Bad placement.”<<endl;
return 0;
}
for(int i=1;i<=r;i)
{
for(int j=1;j<=c;j)
{
if(dir[i][j]==’#’&&st[i][j]==0)
{
ans++;
dfs(i,j);
}
}
}
printf(“There are %d ships.\n”,ans);
return 0;
}