一个地图,不允许走已经走过的,告诉起点,问是否能在第T时间恰好走到终点
其实就是一个DFS,只是有两个地方要注意
1.vis刚开始标记后,在退出DFS的时候要去掉标记
2.一定要剪枝,否则会超时
剪枝可以通过奇偶剪枝,算出起点到重点的曼哈顿距离
然后看曼哈顿距离的奇偶性是否和T的奇偶性一样,如果一样就有可能到,如果不一样,必然不能到,直接输出返回
#include<cstdio> #include<cmath> #include<cstring> #include<queue> #include<cctype> #include<stack> #include<vector> #include<functional> #include<algorithm> using namespace std; typedef long long LL; typedef pair<int, int> PII; const int MX = 10 + 5; const int INF = 0x3f3f3f3f; int m, n; int vis[MX][MX]; char S[MX][MX]; int dist[][2] = {{1, 0}, { -1, 0}, {0, 1}, {0, -1}}; bool DFS(int x, int y, int T) { if(T == 0) { if(S[x][y] == 'D') return true; return false; } vis[x][y] = 1; for(int k = 0; k < 4; k++) { int nx = x + dist[k][0]; int ny = y + dist[k][1]; if(nx < 1 || nx > m || ny < 1 || ny > n) continue; if(S[nx][ny] == 'X' || vis[nx][ny]) continue; if(DFS(nx, ny, T - 1)) return true; } vis[x][y] = 0; return false; } int main() { int T; while(~scanf("%d%d%d", &m, &n, &T), m + n) { PII FST(-1, -1); for(int i = 1; i <= m; i++) { scanf("%s", S[i] + 1); for(int j = 1; j <= n; j++) { if(S[i][j] == 'S') FST = PII(i, j); } } int temp = abs(FST.first - END.first) + abs(FST.second - END.second); if(FST.first == -1 || T % 2 != temp % 2) { printf("NO\n"); continue; } memset(vis, 0, sizeof(vis)); printf("%s\n", DFS(FST.first, FST.second, T) ? "YES" : "NO"); } return 0; }