​LeetCode解法汇总1466. 重新规划路线

news/2024/7/2 23:36:12

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台


描述:

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

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

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

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

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

示例 1:

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

示例 2:

输入: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]

解题思路:

这里使用广度优先搜索的解法,从0出发,先找到一步可以走到的所有节点,如果有反向的,则次数+1。如果正向的则无需处理。

然后找2步可以走到的所有节点,依次下去。

代码:

class Solution {
    Map<Integer, List<Integer>> toMap = new HashMap<>();
    Map<Integer, List<Integer>> fromMap = new HashMap<>();
    boolean[] dp;

    public int minReorder(int n, int[][] connections) {
        dp = new boolean[n];
        for (int[] connection : connections) {
            int from = connection[0];
            int to = connection[1];
            List<Integer> integers1 = toMap.computeIfAbsent(to, k -> new ArrayList<>());
            integers1.add(from);
            List<Integer> integers2 = fromMap.computeIfAbsent(from, k -> new ArrayList<>());
            integers2.add(to);
        }
        int sum = 0;
        List<Integer> list = new ArrayList<>();
        list.add(0);
        dp[0] = true;
        while (list.size() > 0) {
            List<Integer> newList = new ArrayList<>();
            for (int i : list) {
                List<Integer> integers = toMap.get(i);
                List<Integer> integers1 = fromMap.get(i);
                if (integers != null) {
                    for (int key : integers) {
                        if (dp[key]) {
                            continue;
                        }
                        dp[key] = true;
                        newList.add(key);
                    }
                }
                if (integers1 != null) {
                    for (int key : integers1) {
                        if (dp[key]) {
                            continue;
                        }
                        dp[key] = true;
                        sum++;
                        newList.add(key);
                    }
                }
            }
            list = newList;
        }
        return sum;
    }
}


http://lihuaxi.xjx100.cn/news/1886841.html

相关文章

Certbot实现 HTTPS 自动续期

Certbot实现 HTTPS 自动续期 以前阿里云支持申请一年的免费https证书&#xff0c;那每年我们手动更新证书并没什么大问题&#xff0c;但现在阿里云的免费证书仅支持3个月&#xff0c;这意味着每三个月都要要申请一下证书显得非常麻烦。 下面我们使用Certbot实现ssl证书的自动…

Text mining and natural language processing in construction 论文阅读

摘要 文本挖掘 ™ 和自然语言处理 (NLP) 引起了建筑领域的兴趣&#xff0c;因为它们提供了管理和分析基于文本的信息的增强功能。这凸显了需要从施工管理的角度进行系统审查&#xff0c;以确定现状、差距和未来方向。通过将 205 份出版物的目标与施工管理实践中概述的具体领域…

20分钟拥有自己的ChatGPT4,高效低成本,无脑跟即可

准备物品&#xff1a; 1.chatgpt3.5账号 2.美区appstore账号 3.国内visacard不可用&#xff0c;直接充值显示卡过期 直接上成功教程&#xff1a; 1.购买一个美国 AppStore 账号&#xff0c;将账号切换到美区&#xff0c;Appstore→ 头像→最下方→退出登录→更换账号 2.搜…

Redis的四种部署模式:原理、优缺点及应用场景

Redis是一款高性能的开源NoSQL数据库&#xff0c;它支持多种数据结构&#xff0c;如字符串、列表、集合、散列、有序集合等。Redis的主要特点是将所有数据存储在内存中&#xff0c;实现了极高的读写速度&#xff0c;同时也提供了持久化机制&#xff0c;保证了数据的安全性和一致…

汉诺塔问题(C语言)

1.代码: #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h>int func2(int n) {if (n 1){return 1;}else if (n 2){return 3;}return 2 * func2(n - 1) 1; }int func1(int n) {if (n 1){return 1;}else if (n 2){return 2;}return func1(n - 1) func1(n - 2); …

低版本echarts的升级到新版5.4.0的echarts浏览器预警和报错信息

新版5.4.0的echarts浏览器预警和报错信息 [ECharts] DEPRECATED: ‘normal’ hierarchy in itemStyle has been removed since 4.0. All style properties are configured in itemStyle directly now. 因为normal层被移除&#xff0c;问题代码如下图所示 itemStyle: {normal:…

IEEE CSS 系统辨识与自适应控制工具及资料 - system identification andadaptative control

系列文章目录 前言 一、工具软件 1.1 PBSID Toolbox (Predictor-Based Subspace Identification Toolbox) 通过基于预测器的子空间识别工具箱&#xff0c;您可以对 LTI/LPV/Hammerstein/Wiener 系统进行批量或递归识别&#xff08;开环和闭环&#xff09;。 1.2 LTI Toolbo…

我的创作纪念日--数据结构(四)——渐进时间复杂度

&#x1f600;前言 今天是我的创造256天有太多太多的感想和感谢了言不表意在文章体现吧 &#x1f3e0;个人主页&#xff1a;尘觉主页 &#x1f9d1;个人简介&#xff1a;大家好&#xff0c;我是尘觉&#xff0c;希望我的文章可以帮助到大家&#xff0c;您的满意是我的动力&am…