BFS(宽度优先搜索)C++(Acwing)

代码:

#include <cstring>
#include <iostream>
#include <algorithm>using namespace std;typedef pair<int, int> PII;const int N = 110;int n, m;
int g[N][N];
int d[N][N];
PII q[N * N];int bfs()
{int hh = 0, tt = 0;q[0] = {0, 0};memset(d, -1, sizeof d);d[0][0] = 0;int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};while(hh <= tt){auto t = q[hh++];for(int i = 0; i < 4; i++){int x = t.first + dx[i], y = t.second + dy[i];if(x >= 0 && x < n && y >= 0 && y < m && g[x][y] == 0 && d[x][y] == -1){d[x][y] = d[t.first][t.second] + 1;q[++tt] = {x, y};}}}return d[n - 1][m - 1];
}int main()
{cin >> n >> m;for(int i = 0; i < n; i++)for(int j = 0; j < m; j++)cin >> g[i][j];cout << bfs() << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/537758.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

技术分析丨在伺服应用中为什么大多选择行星减速机?

在伺服应用中&#xff0c;反馈装置扮演着至关重要的角色&#xff0c;它通过对线性或旋转系统的扭矩、位置或速度进行精确控制&#xff0c;确保系统的高效、稳定运行。而在这些系统中&#xff0c;负载惯量与电机惯量之比是一个决定系统性能的关键因素。 当负载惯量较低时&#…

社交媒体的明日之星:揭示Facebook如何成为全球最受欢迎的平台之一

在当今数字时代&#xff0c;社交媒体已经成为人们日常生活中不可或缺的一部分。而在这众多社交媒体平台中&#xff0c;Facebook堪称一颗耀眼的明星&#xff0c;其如何成为全球最受欢迎的平台之一&#xff1f;让我们一起揭开这个谜底。 1. Facebook的创立与发展 Facebook由马克…

jupyter notebook 突然莫名奇妙的白屏

jupyter notebook 突然莫名奇妙的白屏 事件背景&#xff1a; 最近在折腾openai&#xff0c;哎&#xff0c;一言难尽&#xff0c;使用的是conda管理python版本的切换&#xff0c;使用jupyter notebook来运行python程序&#xff0c;其实PyCharm也行&#xff0c;但是&#xff0c;…

ChatGPTPLUS、Poe、Claude介绍,以及如何订阅

我使用了FOmepay的556150卡段升级了ChatGPTPLUS、POE、Claude3 一、ChatGPT Plus 是什么&#xff1f; ChatGPT Plus 是基于 ChatGPT 的月订阅升级方案&#xff0c;它可以提供更快的回应速度、更高的可用性以及优先使用到新功能的权限。 ChatGPT Plus 和原版 ChatGPT 的差异 …

前端性能测试工具 LightHouse (灯塔)使用

Lighthouse是什么&#xff1f; —— 一种工具 Lighthouse 是一个开源的自动化工具&#xff0c;用来测试页面性能。 为什么要用Lighthouse&#xff1f;—— 提升用户体验 Web性能可以直接影响业务指标&#xff0c;例如转化率和用户满意度 分析收集各种应用页面性能指标&#xff…

如何在Windows上控制你的iOS游戏?

Windows用户们&#xff0c;是不是常常羡慕iOS用户能畅享那些画面精美、玩法新颖的手机游戏&#xff1f;&#x1f389;不用再望屏兴叹&#xff0c;今天教你如何跨越系统界限&#xff0c;轻松掌控iOS游戏盛宴&#xff01; 使用AirDroid Cast控制功能&#xff0c;即可让Windows操控…

java导入导出excel用注解实现

导入&#xff1a; excel和接收类字段对应关系 Data ColumnWidth(30) public class AppVcardExcelVO {ExcelLineExcelIgnoreSchema(description "导入时候回显行号")private Long lineNum;NotBlank(message "客户名不能为空")ExcelProperty("客户名…

2.案例、鼠标时间类型、事件对象参数

案例 注册事件 <!-- //disabled默认情况用户不能点击 --><input type"button" value"我已阅读用户协议(5)" disabled><script>// 分析&#xff1a;// 1.修改标签中的文字内容// 2.定时器// 3.修改标签的disabled属性// 4.清除定时器// …

jvaweb 3-13

Element 后端开发 maven maven的作用 下载并配置环境变量 创建Maven项目 Maven坐标 依赖 Maven的依赖传递特性 以图表形式展示依赖 排除依赖 依赖范围 生命周期

滑动窗口最大值(leetcode hot100)

给你一个整数数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动窗口中的最大值 。 示例 1&#xff1a; 输入&#xff1a;nums [1,3,-1,-3,5,3,6,7], k 3 输…

拿捏指针(一)

说到指针可能很多人既熟悉又陌生。那么什么是指针呢? 目录 1.0 定义和地址 1.1 指针定义及 1.2 &取地址操作符 1.3 指针变量 2.0 *解引用操作符 2.1 指针解引用 3.0 指针中的const 3.1 const在*号左边 3.2 const在*号右边 4.0 void*指针 5.0 指针的运算 5.1 …

敏捷团队的质量保障赋能

“没有专职的测试人员&#xff1f; 代码提交就直接发布到生产环境&#xff1f; 而且&#xff0c;一天还可以发布多次&#xff1f;” 对于很多团队来说&#xff0c;这是完全不可能的事情&#xff01;他们都是怎么做到的&#xff1f; &#x1f440; 01 两个案例 相信很多人都对前…