1. 写得最有逻辑的一道题了,10次讲座学的最好的就是DFS和BFS了。
2. 直接深搜
#include <iostream> #include <fstream> #include <string> #include <algorithm> #include <cstring> #include <stack> #include <queue> #include <climits> #include <cstdio> #include <cmath> using namespace std; int a, b, sx, sy; char map[25][25]; int num[25][25]; bool flag[25][25]; int dir[8][2] = {{-1, -1}, {0, -1}, {1, -1}, {1, 0}, {1, 1}, {0, 1}, {-1, 1}, {-1, 0}}; bool check(int x, int y) { return (x > 0 && x <= a && y > 0 && y <= b) ? true : false; } void dfs(int x, int y) { int nextx, nexty; flag[x][y] = 1; for (int i = 0; i < 8; i++) { nextx = x + dir[i][0]; nexty = y + dir[i][1]; if ((dir[i][0] == 0 || dir[i][1] == 0) && map[nextx][nexty] != 'X') num[x][y]++; if (check(nextx, nexty) && map[nextx][nexty] == 'X' && flag[nextx][nexty] == 0) dfs(nextx, nexty); } } void init() { for (int i = 0; i < 25; i++) for (int j = 0; j < 25; j++) map[i][j] = '.'; memset(num, 0, sizeof(num)); memset(flag, 0, sizeof(flag)); } int main() { int i, j, ans; while (cin >> a >> b >> sx >> sy) { if (!a && !b) break; init(); for (i = 1; i <= a; i++) for (j = 1; j <= b; j++) cin >> map[i][j]; dfs(sx, sy); ans = 0; for (i = 1; i <= a; i++) for (j = 1; j <= b; j++) ans += num[i][j]; cout << ans << endl; } return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库