news 2026/7/4 9:19:34

2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版

1.题目




2.思路

List<int[]> qu=List of(new int[]{beginX,beginY});
//创建一个 List<int[]>,并把一个二维坐标 (beginX, beginY)(用 int[] 表示)放进去作为列表的第一个元素。
(1)每次从当前位置 (x,y) 走到相邻四格。
int[][] directions={{-1,0},{1,0},{0,-1},{0,1}};
(2)初始化:行列、访问数组、入口坐标
vis 用于防止重复入队导致死循环/超时。

入口先标记已访问。

(3)按层 BFS:从入口开始,每次扩展一圈,ans 记录当前圈的步数;第一次走到边界的可走格就是最近出口,直接返回 ans;没有就返回 -1。

3.代码实现

classSolution{staticint[][]directions={{-1,0},{1,0},{0,-1},{0,1}};publicintnearestExit(char[][]maze,int[]entrance){//行数intm=maze.length;//列数intn=maze[0].length;//标记访问过的元素boolean[][]vis=newboolean[m][n];//起点intbeginX=entrance[0];intbeginY=entrance[1];//访问标记vis[beginX][beginY]=true;//创建一个 List<int[]>,并把一个二维坐标 (beginX, beginY)(用 int[] 表示)放进去作为列表的第一个元素。List<int[]>qu=List.of(newint[]{beginX,beginY});for(intans=1;!qu.isEmpty();ans++){List<int[]>tmp=qu;qu=newArrayList<>();for(int[]p:tmp){//注意起点不算终点,不能在这里判断p是不是终点for(int[]d:directions){//起点不算终点,不能判断p是不是终点intx=p[0]+d[0];inty=p[1]+d[1];//之前没有访问过的元素if(0<=x&&x<m&&0<=y&&y<n&&maze[x][y]=='.'&&vis[x][y]==false){if(x==0||y==0||x==m-1||y==n-1){//到达边界,也就是到达终点returnans;}//访问过的元素进行标记vis[x][y]=true;qu.add(newint[]{x,y});}}}}return-1;//无法到达终点}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 9:25:17

django基于微信小程序的校园食堂点餐订餐系统-计算机毕业设计源码+无LW文档

Django基于微信小程序的校园食堂点餐订餐系统 摘要 本文探讨了利用Django框架结合微信小程序开发校园食堂点餐订餐系统的过程。该系统旨在解决校园食堂在传统点餐模式下存在的排队时间长、效率低等问题&#xff0c;为师生提供便捷的点餐服务&#xff0c;同时提升食堂的管理效率…

作者头像 李华
网站建设 2026/6/28 21:40:49

Comsol 中浆液扩散模型:注浆过程的数字化洞察

comsol注浆&#xff0c;浆液扩散模型在岩土工程、建筑施工等诸多领域&#xff0c;注浆是一项关键技术&#xff0c;它能有效改善土体性质、增强结构稳定性。而理解浆液在地下的扩散规律至关重要&#xff0c;借助 Comsol 建立浆液扩散模型&#xff0c;可让我们在虚拟环境中深入探…

作者头像 李华
网站建设 2026/6/28 22:50:37

2026中专生考大数据与财务管理专业学习指南

行业需求与就业前景数据分析在财务领域的应用日益广泛&#xff0c;企业需要能够处理财务数据并从中提取价值的专业人才。掌握数据分析技能可提升就业竞争力&#xff0c;尤其在金融科技、企业财务分析等岗位需求旺盛。大数据与财务管理专业结合了传统财务知识与现代数据技术&…

作者头像 李华
网站建设 2026/7/1 12:32:00

手把手教你降AI不伤文:保姆级操作让论文既通过检测又保持专业

手把手教你降AI不伤文&#xff1a;保姆级操作让论文既通过检测又保持专业 TL;DR&#xff1a;降AI率最怕的就是把专业术语改没了、论文变得不伦不类。本文教你如何实现「降AI不伤文」&#xff1a;选对工具&#xff08;推荐嘎嘎降AI&#xff09;、分段处理、处理后校对。掌握这套…

作者头像 李华
网站建设 2026/6/29 0:22:28

小程序毕设选题推荐:基于django+微信小程序的健康生活系统个人健康生活平台小程序【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/29 14:55:07

微分方程一维抛物热传导方程数值解法全解析

微分方程一维抛物热传导方程向前向后欧拉C-N格式二阶BDF格式MATLAB源码 显式欧拉&#xff0c;隐式欧拉&#xff0c;梯形公式&#xff0c;改进欧拉 五点差分&#xff0c;九点差分 差分格式&#xff0c;紧差分格式 直拍&#xff0c;只有pdf版方法说明 word版 公式纯手打 数值例子…

作者头像 李华