挑战程序设计竞赛 2.1章习题 Aizu - 0558 Cheese BFS
地址 https://vjudge.net/problem/Aizu-0558
题意大意是 给予一个矩阵,S是起点 .是可以通过的通道 X是不可通过区域, 数字表示各种硬度的强度, 如果小老鼠按照硬度的次序吃下这些奶酪,请问最小要走多少步(上下左右移动一次算一步,可经过奶酪但是不吃) 输入格式为 第一行 三个数字 H,W,N H代表矩阵的高度 W代表矩阵的宽度 N代表各个奶酪的硬度范围 H,W,N (1 ≤ H ≤ 1000,1 ≤ W ≤ 1000,1 ≤ N ≤ 9) 然后输入包含SX.和数字的矩阵 输入格式为 一行 输出吃完奶酪的最小步骤 入力例 1 3 3 1 S.. ... ..1 出力例 1 4 入力例 2 4 5 2 .X..1 ....X .XX.S .2.X. 出力例 2 12 入力例 3 10 10 9 .X...X.S.X 6..5X..X1X ...XXXX..X X..9X...X. 8.X2X..X3X ...XX.X4.. XX....7X.. X..X..XX.. X...X.XX.. ..X....... 出力例 3 91
题解
使用bfs求得最小步数
只是每次的BFS起点和终点是不同的
第一次是起终点是开始的位置和硬度为1的奶酪坐标。
然后的起终点是硬度为1 的奶酪和硬度为2的奶酪坐标
// 1123555.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。 // #include <iostream> #include <vector> #include <memory.h> #include <queue> using namespace std; const int N = 1010; char graph[N][N]; int vis[N][N]; int n, m, cnt; int targetX[11]; int targetY[11]; int ans; int addX[4] = { 1,-1,0,0 }; int addY[4] = { 0,0,-1,1 }; void bfs(int startX,int startY, int endX, int endY) { memset(vis, 0, sizeof vis); queue <vector<int>> q; q.push({ startX ,startY ,0}); vis[startX][startY] = 1; while (!q.empty()) { vector<int> v = q.front(); q.pop(); int step = v[2]; //找到了目标奶酪 if (v[0] == endX && v[1] == endY) { ans += step; return; } for (int i = 0; i < 4; i++) { int newx = v[0] + addX[i]; int newy = v[1] + addY[i]; if (newx >= 0 && newx < n && newy >= 0 && newy < m && vis[newx][newy] == 0 && graph[newx][newy] != 'X') { q.push({newx,newy,step+1}); vis[newx][newy]=1; } } } return ; } int main() { cin >> n >> m >> cnt; int startX = -1; int startY = -1; int endX = -1; int endY = -1; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { cin >> graph[i][j]; if (graph[i][j] == 'S') { startX = i; startY = j; endX = i; endY = j; } else if (graph[i][j] != '.' && graph[i][j] != 'X') { int idx = graph[i][j] - '0'; targetX[idx] = i; targetY[idx] = j; } } } for (int i = 1; i <= cnt;i++) { startX = endX; startY = endY; endX = targetX[i]; endY = targetY[i]; bfs(startX, startY,endX,endY); } cout << ans<<endl; return 0; }
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力


【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话