当前位置: 首页 > news >正文

--- 单源BFS权值为一算法 迷宫中离入口最近的出口 ---

单源bfs,从一个固定的点开始向外遍历找到一个离自己最近的点,而当他向外遍历时,第一次碰到了满足要求的点,那么这时这一条路就是最近的,对应到这道题就是从entrance遍历到边界的最近的出口,而为什么第一次bfs到他就是最近的?

可以这样理解,每一次bfs就相当于从这个点开始向外的每个点都走了一步,这样就走出了不同的路径,让后当有个点路径第一次走到了出口,那么他就时最近的,因为每一条路径的权值都是相同的

bfs的实现

将固定源储存在一个队列中,以这个点为原点开始向四周遍历,记为第一层,四周遍历的点又储存在队列中,记为第二层的节点,当吧第一层的所有节点出完,点第二层的节点也遍历完了,这时队列中的全是第二层的节点了,这就完成了一层的bfs,重复这个过程,直到队列为空,那么就完成了层序遍历

    int[] dx = {0, 0, -1, 1};int[] dy = {-1, 1, 0, 0};public int nearestExit(char[][] maze, int[] entrance) {int m = maze.length;int n = maze[0].length;boolean[][] check = new boolean[m][n];List<int[]> list = new LinkedList<>();list.add(new int[]{entrance[0], entrance[1]});check[entrance[0]][entrance[1]] = true;int times = 0;while (!list.isEmpty()) {times++;int size = list.size();for (int i = 0; i < size; i++) {int[] arr = list.remove(0);for (int j = 0; j < 4; j++) {int yy = arr[0] + dy[j];int xx = arr[1] + dx[j];if (yy < 0 || yy == m || xx < 0 || xx == n || check[yy][xx] || maze[yy][xx] == '+') continue;if (yy == 0 || yy == m - 1 || xx == 0 || xx == n - 1) {return times;}check[yy][xx] = true;list.add(new int[]{yy, xx});}}}return -1;}

类似的题还有

最小基因变化 单词接龙 diff 为高尔夫砍树

http://www.dtcms.com/a/545451.html

相关文章:

  • LVGL3(Helloworld)
  • 量化交易网站开发自己的网站做弹出广告
  • 三明市建设局网站官网网络营销方案
  • CODESYS中基于CAA File库的CSV文件读写与表格可视化全解析
  • PRA(流程机器人自动化)与智能体(AI Agent)主要区别与分析
  • GPT-3 技术报告
  • C++数据结构(链表和list)
  • 【Maven】mac安装maven
  • 有哪些网站能够免费找到素材wordpress 制作小工具栏
  • 深入剖析:仓颉语言的性能优化核心技术
  • .Net Core基于EasyCore.EventBus实现事件总线
  • 公司怎么做网站推广郑州包装设计公司
  • 阿里云服务器上构建基于PoS的以太坊2.0私有链
  • 如何把网站推广出编程代码怎么学
  • C++ 单调栈
  • 电商网站开发 上海wordpress 登陆 没反应
  • 服务器网站备案wordpress三道杠菜单
  • mysql upsert 用法(批量保存或更新)
  • 海康相机与机器人标定
  • 十年后,AI会赋予工业怎样的力量?
  • 西安市建设协会网站高级搜索入口
  • 东莞个人网站推广建设做中东市场哪个网站合适
  • Spring Boot 3 整合 LiteFlow:轻量级流程编排框架学习
  • Rust:WebSocket支持的实现
  • 代刷开通建设网站Wordpress怎么添加购买页面
  • 做网站几个步骤网址推荐你会感谢我的
  • 黑马商城day7-消息可靠性
  • wpsapi
  • Postman实现jwt发送请求
  • 网站正在备案什么是网络营销 职能是什么