OD_2024_C卷_200分_3、电脑病毒感染【JAVA】【图论 / 单源最短路径(dijkstra)】

news/2024/5/19 7:37:04 标签: java, 图论, OD

题目描述

一个局域网内有很多台电脑,分别标注为 0 ~ N-1 的数字。相连接的电脑距离不一样,所以感染时间不一样,感染时间用 t 表示。

其中网络内一台电脑被病毒感染,求其感染网络内所有的电脑最少需要多长时间。如果最后有电脑不会感染,则返回-1。

给定一个数组 times 表示一台电脑把相邻电脑感染所用的时间。

如图:path[i] = {i, j, t} 表示:电脑 i->j,电脑 i 上的病毒感染 j,需要时间 t。

输入描述

4
3
2 1 1
2 3 1
3 4 1
2

输出描述

2

用例1

输入

4
3
2 1 1
2 3 1
3 4 1
2

输出

2

说明

第一个参数:局域网内电脑个数N,1 ≤ N ≤ 200;

第二个参数:总共多少条网络连接

第三个 2 1 1 表示2->1时间为1

第六行:表示病毒最开始所在电脑号2

代码

java">package odjava;

import java.util.*;

public class 三_电脑病毒感染 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        // 读取节点数和边数
        int n = sc.nextInt(); // 节点数
        int m = sc.nextInt(); // 边数

        // 创建邻接表来表示图
        HashMap<Integer, ArrayList<int[]>> graph = new HashMap<>();

        // 读取边的信息并构建邻接表
        for (int i = 0; i < m; i++) {
            int u = sc.nextInt(); // 出发点
            int v = sc.nextInt(); // 目标点
            int w = sc.nextInt(); // 出发点到达目标点的耗时

            // 添加边到邻接表
            graph.putIfAbsent(u, new ArrayList<>());
            graph.get(u).add(new int[]{v, w});
        }

        // 记录源点到其他节点的最短耗时
        int[] dist = new int[n + 1];
        // 初始化源点到其他节点的最短耗时为无穷大
        Arrays.fill(dist, Integer.MAX_VALUE);

        // 源点的编号
        int src = sc.nextInt();
        // 源点到自身的最短耗时为0
        dist[src] = 0;

        // 创建优先队列,用于存储待探索的节点
        // 优先队列中节点的优先级按照其到源点的距离排序,距离越小优先级越高
        PriorityQueue<Integer> needCheck = new PriorityQueue<>((a, b) -> dist[a] - dist[b]);
        // 将源点加入优先队列
        needCheck.add(src);

        // 记录节点是否已经被访问过
        boolean[] visited = new boolean[n + 1];
        visited[src] = true;

        // 进行 Dijkstra 算法的核心步骤,找到源点到其他节点的最短路径
        while (!needCheck.isEmpty()) {
            // 取出当前最短距离的节点
            int cur = needCheck.poll();
            visited[cur] = false;

            // 遍历当前节点的所有邻居节点
            if (graph.containsKey(cur)) {
                for (int[] next : graph.get(cur)) {
                    int v = next[0]; // 邻居节点编号
                    int w = next[1]; // 当前节点到邻居节点的边的权重

                    // 计算从源点经当前节点到达邻居节点的距离
                    int newDist = dist[cur] + w;

                    // 如果新距离比之前记录的距离要小,则更新距离并加入优先队列
                    if (newDist < dist[v]) {
                        dist[v] = newDist; // 更新距离
                        if (!visited[v]) {
                            // 如果邻居节点不在优先队列中,则将其加入队列
                            visited[v] = true;
                            needCheck.add(v);
                        }
                    }
                }
            }
        }

        // 找到源点到其他节点的最大耗时,即最长路径
        int maxTime = 0;
        for (int i = 1; i <= n; i++) {
            maxTime = Math.max(maxTime, dist[i]);
        }

        // 如果存在无法到达的节点,则输出 -1;否则输出最大耗时
        System.out.println(maxTime == Integer.MAX_VALUE ? -1 : maxTime);
    }
}



http://www.niftyadmin.cn/n/5420730.html

相关文章

HBase安装,配置,启动,检查

目录: 一、HBase安装&#xff0c;配置 1、下载HBase安装包 2、解压&#xff0c;配置环境变量并激活 3、hbase 配置 4、将hadoop和zookeeper的配置文件创建软连接放在hbase配置目录 5、配置 regionserver 二、HBase启动与关闭&#xff0c;安装检验 1、启动关闭hbase的命令 2、 检…

Vue3+Vue Router使用<transition>过渡动画实现左右分栏后台布局

摘要 利用Vue3及其配套的Vue Router实现后台管理系统中的页面过渡动画。文章首先简要介绍了Vue3的特性和Vue Router的基本用法&#xff0c;利用Vue3提供的组件以及Vue Router的路由钩子函数来实现页面过渡效果。 代码结构 在 components 里有4个组件&#xff0c;其中 Layout…

【原创教程】S7-1200配方程序编写方法

1 绪论 1.1 本文的目的 在生产中我们的一台设备往往需要 对应很多种不同工艺或不同尺寸的设备,这就要求我们设备的参数需要经常变化。我们将每一种产品对应的参数保存起来,下一次再生产同种产品时可以迅速一键调用,而不是一个一个的去设置,这种功能就叫做配方(Recipe)。…

3.10 log | 647. 回文子串

647. 回文子串&#xff0c;516.最长回文子序列 class Solution { public:int countSubstrings(string s) {vector<vector<bool>> dp(s.size(),vector<bool>(s.size(),false));int result0;for(int is.size()-1;i>0;i--){for(int ji;j<s.size();j){if(…

POS 之 奖励机制

为什么需要有奖惩机制 如果没有奖励&#xff0c;就不会有节点参与POS&#xff0c;运营节点有成本&#xff0c;而奖励正是让运营者获利的方式 如果没有惩罚&#xff0c;网络上会充斥着很多无效节点&#xff0c;会扰乱甚至破坏网络 所有奖励和惩罚在每个 Epoch 实施一次 奖励 什…

鸿蒙OS应用开发之显示图片组件11

前面学习了像素降级处理的方法,这样方便一个图片可以显示在不同大小屏幕的技术,同样不会失真。现在来学习另外一个重要的技术,就是图片处理。图片处理是一个很范的名词,一般来说图片处理都会采用预处理的方法,比如在电脑上采用图形处理软件进行处理,然后再使用到手机的软…

深入理解React中的useReducer:管理复杂状态逻辑的利器

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Spring MVC配置MyBatis vs. Spring Boot配置MyBatis

在Java Web开发中&#xff0c;MyBatis是一个常用的持久层框架&#xff0c;用于简化数据库访问操作。在Spring框架中&#xff0c;我们可以通过Spring MVC和Spring Boot两种方式来集成MyBatis&#xff0c;本文将比较这两种方式的优缺点&#xff0c;并展示它们的具体代码实现。 S…