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

LC-1466. 重新规划路线(DFS、BFS)

1466. 重新规划路线

中等

n 座城市,从 0n-1 编号,其间共有 n-1 条路线。因此,要想在两座不同城市之间旅行只有唯一一条路线可供选择(路线网形成一颗树)。去年,交通运输部决定重新规划路线,以改变交通拥堵的状况。

路线用 connections 表示,其中 connections[i] = [a, b] 表示从城市 ab 的一条有向路线。

今年,城市 0 将会举办一场大型比赛,很多游客都想前往城市 0 。

请你帮助重新规划路线方向,使每个城市都可以访问城市 0 。返回需要变更方向的最小路线数。

题目数据 保证 每个城市在重新规划路线方向后都能到达城市 0 。

示例 1:

img

输入:n = 6, connections = [[0,1],[1,3],[2,3],[4,0],[4,5]]
输出:3
解释:更改以红色显示的路线的方向,使每个城市都可以到达城市 0 。

示例 2:

img

输入:n = 5, connections = [[1,0],[1,2],[3,2],[3,4]]
输出:2
解释:更改以红色显示的路线的方向,使每个城市都可以到达城市 0 。

示例 3:

输入:n = 3, connections = [[1,0],[2,0]]
输出:0

提示:

  • 2 <= n <= 5 * 10^4
  • connections.length == n-1
  • connections[i].length == 2
  • 0 <= connections[i][0], connections[i][1] <= n-1
  • connections[i][0] != connections[i][1]

BFS

class Solution {/**构件图时标志是正边还是反边,一次bfs如果是反边则需要res+1*/List<int[]>[] g;public int minReorder(int n, int[][] connections) {g = new ArrayList[n];Arrays.setAll(g, e -> new ArrayList<int[]>());for(int[] c : connections){int x = c[0], y = c[1];g[x].add(new int[]{y, -1}); // 1标志正边,-1标志反边g[y].add(new int[]{x, 1});}boolean[] vis = new boolean[n];Deque<Integer> dq = new ArrayDeque<>();dq.add(0);vis[0] = true;int res = 0;while(!dq.isEmpty()){int x = dq.pollLast();for(int[] q : g[x]){int y = q[0], dir = q[1];if(vis[y]) continue;vis[y] = true;if(dir == -1) res += 1;dq.addFirst(y);}}return res;}
}

DFS

class Solution {   List<int[]>[] g;int res = 0;boolean[] vis;public int minReorder(int n, int[][] connections) {g = new ArrayList[n];Arrays.setAll(g, e -> new ArrayList<int[]>());for(int[] c : connections){int x = c[0], y = c[1];g[x].add(new int[]{y, -1}); // 1标志正边,-1标志反边g[y].add(new int[]{x, 1});}vis = new boolean[n];dfs(0, -1);return res;}public void dfs(int x, int fa){vis[x] = true;for(int[] q : g[x]){int y = q[0], dir = q[1];if(vis[y]) continue;if(dir == -1) res += 1;dfs(y, x);}}
}
http://www.lryc.cn/news/254689.html

相关文章:

  • 自动数据增广论文笔记 | AutoAugment: Learning Augmentation Strategies from Data
  • CTF 7
  • 无公网IP环境Windows系统使用VNC远程连接Deepin桌面
  • java--枚举
  • JVM垃圾回收机制GC
  • 详解JAVA中的@ApiModel和@ApiModelProperty注解
  • TiDB专题---2、TiDB整体架构和应用场景
  • 性能调优入门
  • JavaWeb | 验证码 、 文件的“上传”与“下载”
  • 服务器感染了.halo勒索病毒,如何确保数据文件完整恢复?
  • docker安装elasticsearch8.5.0和kibana
  • 如何使用内网穿透工具实现公网访问GeoServe Web管理界面
  • koa2项目中封装log4js日志输出
  • C# WPF上位机开发(抽奖软件)
  • 搭建部署Hadoop2.x和3.x的区别
  • Java爬虫攻略:应对JavaScript登录表单
  • 基于单片机的电子密码锁设计
  • ChatGPT学习笔记
  • One-to-Few Label Assignment for End-to-End Dense Detection阅读笔记
  • Ubuntu22.04 使用Docker部署Neo4j出错 Exited(70)
  • 【数据分析 | Numpy】Numpy模块系列指南(一),从设计架构说起
  • 多人聊天室
  • 智慧园区可视化综合管理平台建设方案,智能化、数字化才是关键
  • kepler.gl部署在线说明文档
  • Java程序员,你掌握了多线程吗?
  • Android 11.0 长按按键切换SIM卡默认移动数据
  • Kafka集群调优+能力探底
  • netcore swagger 错误 Failed to load API definition
  • UDP Socket API 的讲解,以及回显服务器客户端的实现
  • 数据结构与算法-D7栈实现及应用