HDU1010第一道DFS
DFS就是深度搜索算法。。。。感觉就像破案一样。。。。
#include<iostream> #include<cstdio> #include<cstring> #define maxn 10 using namespace std; char map[maxn][maxn]; int mat[maxn][maxn]; int st_x, st_y; int m, n, t; int flag; void dfs(int x, int y, int ti) { if(flag||ti > t) return; else if(map[x][y] == 'D') { if(ti == t) flag = 1; return ; } else if(map[x][y] == '.' || map[x][y] == 'S') { mat[x][y] = 1; if(x - 1 >= 1 && x - 1 <= m && y >= 1 && y <= n && !mat[x - 1][y]) dfs(x - 1, y, ti + 1); if(x + 1 >= 1 && x + 1 <= m && y >= 1 && y <= n && !mat[x + 1][y]) dfs(x + 1, y, ti + 1); if(x >= 1 && x <= m && y + 1 >= 1 && y + 1 <= n && !mat[x][y + 1]) dfs(x, y + 1, ti + 1); if(x >= 1 && x <= m && y - 1 >= 1 && y - 1 <= n && !mat[x][y - 1]) dfs(x, y - 1, ti + 1); mat[x][y] = 0; } } int main() { while(scanf("%d%d%d", &m, &n, &t) != EOF, m + n + t) { int i, j; for(i = 1; i <= m; i ++) { for(j = 1; j <= n; j ++) { cin >> map[i][j]; if(map[i][j] == 'S') { st_x = i; st_y = j; } } } flag = 0; dfs(st_x, st_y, 0); if(flag) cout << "YES" << endl; else cout << "NO" << endl; memset(map, 0, sizeof(map)); memset(mat, 0, sizeof(mat)); } }
本文来自博客园,作者:MrYu4,转载请注明原文链接:https://www.cnblogs.com/MrYU4/p/15778917.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了