现在,我们用大炮来打蚊子:蚊子分布在一个M×N格的二维平面上,每只蚊子占据一格。向该平面的任意位置发射炮弹,炮弹的杀伤范围如下示意:
OOXOO
其中,X
为炮弹落点中心,O
为紧靠中心的四个有杀伤力的格子范围。若蚊子被炮弹命中(位于X
格),一击毙命,若仅被杀伤(位于O
格),则损失一半的生命力。也就是说,一次命中或者两次杀伤均可消灭蚊子。现在给出蚊子的分布情况以及连续k
发炮弹的落点,给出每炮消灭的蚊子数。
输入格式:
第一行为两个不超过20的正整数M
和N
,中间空一格,表示二维平面有M
行、N
列。
接下来M
行,每行有N
个0
或者#
字符,其中#
表示所在格子有蚊子。
接下来一行,包含一个不超过400的正整数k
,表示发射炮弹的数量。
最后k
行,每行包括一发炮弹的整数坐标x
和y
(0≤x
<M
,0≤y
<N
),之间用一个空格间隔。
输出格式:
对应输入的k
发炮弹,输出共有k
行,第i
行即第i
发炮弹消灭的蚊子数。
输入样例:
5 600#00#000###00#00000000000#00021 21 4
输出样例:
02
visit数组标记有无蚊子,ope标记蚊子状况。
#include<iostream>#include<cstdio>#include<algorithm>#include<cstring>using namespace std;const int maxn = 22;char G[maxn][maxn];bool visit[maxn][maxn] = {0};bool ope[maxn][maxn]={0};int main(){int n,m;cin>>n>>m;int ans;for(int i = 0;i<n;i++){for(int j = 0;j<m;j++){cin>>G[i][j];if(G[i][j] == '#'){visit[i][j] = 1;//代表有蚊子}}}int k;cin>>k; //ope代表被炸了几次for(int i = 0;i<k;i++){ans = 0;int x,y;cin>>x>>y; //轰炸点有蚊子直接死,蚊子标记点改为0if(visit[x][y] == 1){ans++;visit[x][y]=0;}if(visit[x][y+1] == 1){ //遍历四周,ope为1表示蚊子受伤if(ope[x][y+1] == 1){//如果在这次伤到蚊子之前蚊子已经受伤则该位子蚊子死亡,visit改为0ans++;visit[x][y+1] = 0;}else{ope[x][y+1] = 1;}}if(visit[x+1][y] == 1){if(ope[x+1][y] == 1){ans++;visit[x+1][y] = 0;}else{ope[x+1][y] = 1;}}if(visit[x-1][y] == 1&&x-1>=0){if(ope[x-1][y] == 1){ans++;visit[x-1][y] = 0;}else{ope[x-1][y] = 1;}}if(visit[x][y-1] == 1&&y-1>=0){if(ope[x][y-1] == 1){ans++;visit[x][y-1] = 0;}else{ope[x][y-1] = 1;}}if(i!=k-1)cout<<ans<<endl;elsecout<<ans;}}
02