由于题目是日语,所以直接写翻译
题目描述
我们有一个 HH 横行 WW 竖列的网格,其中有一些格是障碍。
我们约定 (i,j)(i,j) 为从上到下第 ii 行、从左到右第 jj 行的格。
给你 HH 个字符串 S1,S2,S3,…,SHS1,S2,S3,…,SH。SiSi 的第 jj 个字符为格 (i,j)(i,j):#
表示是障碍格,.
表示不是障碍格。
当这个格和另一个格在同一行或者同一列上,并且它们两个之间没有障碍(包括它们自己)时,我们说这个格是 可见的。
输出在格 (X,Y) 上 可见的 格数(包括它本身)。
输入
输入从标准输入(stdin)给出,并遵循以下格式:
H W X Y
S1
S2
S3
.
.
.
SH
输出
输出答案。
输入数据 1
4 4 2 2
##..
...#
#.#.
.#.#
Copy
输出数据 1
4
Copy
样例解释 1
从格 (2,2) 可见的格有:
- (2,1)
- (2,2)
- (2,3)
- (3,2)
输入数据 2
3 5 1 4
#....
#####
....#
Copy
输出数据 2
4
Copy
输入数据 3
5 5 4 2
.#..#
#.###
##...
#..#.
#.###
Copy
输出数据 3
3
Copy
参考程序:
点个赞再走吧
#include<bits/stdc++.h>
using namespace std;
int h,w,x,y,ans=1;
char s[105][105];
int main()
{
cin>>h>>w>>x>>y;
for(int i=1;i<=h;i++){
for(int j=1;j<=w;j++){
cin>>s[i][j];
}
}
for(int i=x-1;i>=1;i--){
if(s[i][y]=='#'){
break;
}
else{
ans++;
}
}
for(int i=x+1;i<=h;i++){
if(s[i][y]=='#'){
break;
}
else{
ans++;
}
}
for(int i=y-1;i>=1;i--){
if(s[x][i]=='#'){
break;
}
else{
ans++;
}
}
for(int i=y+1;i<=w;i++){
if(s[x][i]=='#'){
break;
}
else{
ans++;
}
}
cout<<ans;
}
//还是没有注释很棒吧