我这种算什么方法,最终已过

P11228 [CSP-J 2024] 地图探险

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


|