SnowZ @ 2024-10-28 00:10:07
#include <bits/stdc++.h>
using namespace std;
int T;
int n, m, k;
int sx, sy, sd;
int ans = 0, cnt = 0;
bool st[1020][1020];
char dt[1020][1020];
void move(int cnt, int d, int x, int y)
{
if(st[x][y])
{
st[x][y] = false;
ans++;
}
if(cnt > k)
{
printf("%d\n",ans);
ans = 0;
return;
}
int nextStep[4][2] = {
{x, y+1},
{x+1, y},
{x, y-1},
{x-1, y},
};
int nx = nextStep[d][0], ny = nextStep[d][1];
if(nx < 1 || nx > n || ny < 1 || ny > m || dt[nx][ny] == 'x')
{
d = (d+1) % 4;
}
else
{
x = nx;
y = ny;
}
move(cnt+1, d, x, y);
}
int main()
{
cin >> T;
for(int ti = 0; ti < T; ti++)
{
cin >> n >> m >> k;
cin >> sx >> sy >> sd;
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= m; j++)
{
cin >> dt[i][j];
if(dt[i][j] == '.')
{
st[i][j] = true;
}
else st[i][j] = false;
}
}
move(1, sd, sx, sy);
}
return 0;
}
by xiaozhisoc @ 2024-10-28 10:10:12
递归实现的模拟 :D