LeetCode-网络延迟时间(Dijkstra算法)

2024-05-03 00:20

本文主要是介绍LeetCode-网络延迟时间(Dijkstra算法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

每日一题

今天刷到一道有关的图的题,需要求单源最短路径,因此使用Dijkstra算法。

题目要求

有 n 个网络节点,标记为 1 到 n

给你一个列表 times,表示信号经过 有向 边的传递时间。 times[i] = (ui, vi, wi),其中 ui 是源节点,vi 是目标节点, wi 是一个信号从源节点传递到目标节点的时间。

现在,从某个节点 K 发出一个信号。需要多久才能使所有节点都收到信号?如果不能使所有节点收到信号,返回 -1 。

示例 1:

输入:times = [[2,1,1],[2,3,1],[3,4,1]], n = 4, k = 2
输出:2

示例 2:

输入:times = [[1,2,1]], n = 2, k = 1
输出:1

示例 3:

输入:times = [[1,2,1]], n = 2, k = 2
输出:-1

题目解析

题目中给了几个节点,并且给了节点之间的距离,要求我们从指定的某个节点发送信号。需要多久所有节点可以收到,这个明显要求从某个节点到所有节点的最短距离,因此可以采用Dijkstra。

Dijkstra算法

Dijkstra算法是一种用于解决单源最短路径问题的经典算法,由荷兰计算机科学家艾兹赫尔·迪科斯彻(Edsger W. Dijkstra)于1956年提出。该算法可以在加权图中找到从起始节点到所有其他节点的最短路径。

算法思想

  1. 初始化:将起始节点的距离设为0,其他节点的距离设为无穷大(或一个很大的值),并将所有节点标记为未访问。

  2. 遍历节点:从起始节点开始,依次遍历所有节点。

  3. 更新距离:对于当前节点的所有邻居节点,计算从起始节点经过当前节点到达邻居节点的距离。如果经过当前节点到达邻居节点的距离小于目前已知的最短距离,则更新邻居节点的距离值为经过当前节点到达邻居节点的距离,并标记当前节点为邻居节点的前驱节点。

  4. 选择下一个节点:从所有未访问的节点中选择距离起始节点最近的节点作为下一个当前节点,并标记该节点为已访问。

  5. 重复步骤3和4,直到所有节点都被访问过,或者目标节点的距离值被确定。

算法特点

  • Dijkstra算法适用于没有负权边的加权有向图或无向图。
  • 算法保证了在每一步选择当前最短路径的节点,因此得到的结果是最优解。
  • 算法的时间复杂度为O(V^2),其中V是图中节点的数量。如果使用优先队列(如最小堆)来存储和选择距离最近的节点,时间复杂度可以优化到O(E + VlogV),其中E是图中边的数量。

图解流程如下:

使用此算法需要两个数组,一个dist数组用来记录第k个节点到所有的节点最短距离,一个visited数组记录某个节点是否被访问过。

那么针对于这道题来说,我们一共需要创建三个数组

一个二维graph[i][j]数组,用来记录当前记录下的从i到j的距离

一个dist数组,记录第k个节点到所有的节点最短距离

一个used数组记录某个节点是否被访问过。

首先先将graph数组初始化,将距离全部设为最大。随后遍历给的times数组,记录下已经给出的节点间的距离。随后同步到dist数组中。

随后开始循环n-1次,在循环中嵌套循环,找到所有未访问节点中距离k最近的节点‘u’并记录下来已经访问过了。如果循环完毕后发现从k到不了某个未节点,则直接返回-1.最后再次进入一次循环,循环中对于节点j来说,判断是直接从k到j的距离小还是从可先到u再到j的距离小,因为我们刚得到了从k到u的最短距离,找到谁最小,赋值给dist[j].

最后经过多次循环,从k到所有节点的距离就存储在了dist中了,找到其中的最大的值就是我们要的答案。

代码实现

class Solution {public int networkDelayTime(int[][] times, int n, int k) {final int INF = Integer.MAX_VALUE / 2;int[][] graph = new int[n][n];boolean[] used = new boolean[n];int[] dist = new int[n];Arrays.fill(dist, INF);for (int i = 0; i < n; i++) {Arrays.fill(graph[i], INF);}for (int[] time : times) {graph[time[0] - 1][time[1] - 1] = time[2];}for (int i = 0; i < n; i++) { dist[i] = graph[k - 1][i];}dist[k - 1] = 0;used[k - 1] = true;for (int i = 0; i < n - 1; i++) {int min = INF;int u = -1;for (int j = 0; j < n; j++) {if (!used[j] && dist[j] < min) {min = dist[j];u = j;}}if (u == -1) {return -1;}used[u] = true;for (int j = 0; j < n; j++) {if (!used[j] && graph[u][j] + dist[u] < dist[j]) {dist[j] = graph[u][j] + dist[u];}}}int ans = 0;for (int i = 0; i < n; i++) {ans = Math.max(ans, dist[i]);}return ans == INF ? -1 : ans;}
}

这篇关于LeetCode-网络延迟时间(Dijkstra算法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/955454

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ