leetcode-743. 网络延迟时间

news2024/11/25 9:21:52

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.思路分析:

一道Dijkstra模板题
推荐Dijkstra算法讲解教程

Dijkstra(有向图某点到其他所有点的最短路径问题)

Dijkstra算法的基本思想是贪心策略,每次从未确定最短路径的顶点中选择距离源点最近的一个,然后以该顶点为中介,更新其他顶点到源点的距离。这个过程重复执行,直到所有顶点都确定了最短路径。

Dijkstra算法的时间复杂度取决于使用的数据结构,如果使用数组或链表存储顶点集合,时间复杂度为O(n^2),如果使用优先队列或二叉堆存储顶点集合,时间复杂度为O((m+n)logn),其中n是顶点数,m是边数。

Dijkstra算法的一个重要条件是图中不能有负权边,否则算法可能无法得到正确的结果

本题思路

创建一个具有双向链表的节点类Node,

class Node{
	int key;
    int value;
	Node prev;
	Node next;
	public Node(int value){
		this.value = value;	
	}
}

创建一个双向链表类DoubleLinkList,实现头尾虚拟节点,并且初始化他们的相互连接。
并且实现删除头结点,插入节点,插入尾节点功能。
再借助DoubleLinkList实现题目中的LRUCache类。

2. 算法实现

static int[][] map ;
static int INF = Integer.MAX_VALUE;
static int[] dis;
static int[] flag;
public static int networkDelayTime(int[][] times, int n, int k) {
    //n是点的数量,k是起点
    map = new int[n][n];//点与点之间的边连接情况
    dis = new int[n];//最短路径数组
    flag = new int[n];//已访问过的数组
    flag[k - 1] = 1;
    for(int i = 0;i < n;i++){//初始化图,各个点之间都不连通
        for(int j = 0;j < n;j++){
            map[i][j] = INF;
        }
    }
    for(int i = 0;i < times.length;i++){//将题目中的边初始化到图中
        map[times[i][0] - 1][times[i][1] - 1] = times[i][2];
    }
    for(int i = 0;i < n;i++){//将起始点到其他各个点的距离初始化到最短路径数组中
        dis[i] = map[k - 1][i];
    }
    dis[k - 1] = 0;//自己到自己初始化为0
    //Dijikstra
    int loop = 0;
    while(loop < n - 1){//循环总点数-1次,访问其他点到源点的最短距离
        int min = INF;
        int minIndex = -1;
        for(int i = 0;i < n;i++){//找到当前还未访问的点中距离源地最近的点
            if(min > dis[i] && flag[i] == 0){
                min = dis[i];
                minIndex = i;
            }
        }
        if(minIndex != -1){//当前距离源点最近的点标记为访问过
            flag[minIndex] = 1;
        }else{//当前未访问的点到源点都不可达
            return -1;
        }
        for(int i = 0;i < n;i++){//以当前到源点最近的点为中间点
            if(map[minIndex][i] != INF && flag[i] != 1){//遍历的点未被访问过,并且当前中间点到该点可达
                if(dis[minIndex] + map[minIndex][i] < dis[i]){
                    dis[i] = dis[minIndex] + map[minIndex][i];
                }
            }
        }
        loop++;
    }
    int max = Integer.MIN_VALUE;
    for(int val : dis){
        if(val == INF){
            return -1;
        }else if(max < val){
            max = val;
        }
    }
    return max;
}

3. 算法坑点

  1. 注意笨题解采用邻接表实现图,题目给出的是从1开始的序号,记得把序号-1,再对map中对应下标的值进行操作。(因为map是二维数组,下标默认从0开始)
  2. 以下这段代码是找当前还未访问过的点钟距离源点最近的点,
int min = INF;
int minIndex = -1;
for(int i = 0;i < n;i++){//找到当前还未访问的点中距离源地最近的点
    if(min > dis[i] && flag[i] == 0){
        min = dis[i];
        minIndex = i;
    }
}
flag[minIndex] = 1;//当前距离源点最近的点标记为访问过

但是min初始化为INF,有可能有个潜在的情况,当前未访问的所有的点到源点都是不可达,即距离为INF,此时在flag[minIndex] = 1赋值前做一个判断。

if(minIndex != -1){//当前距离源点最近的点标记为访问过
    flag[minIndex] = 1;
}else{//当前未访问的点到源点都不可达
    return -1;
}
  1. 在比较源点到中间点最短距离+中间点到剩余未访问的点距离源点到中间点最短距离时,注意其他点应该是未被访问过的。
 if(flag[i] != 1 && map[minIndex][i] != INF)//flag[i] != 1 未被访问过的,并且中间点到未访问点之间可达

为什么其他点应该是未被访问过的,因为访问过的点已经找到最短路径了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/552204.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python使用正则表达式

正则表达式&#xff08;Regular Expression&#xff09;&#xff0c;又称规则表达式&#xff0c;是一个计算机科学的概念&#xff0c;通常被用来检索和替换符合某些规则的文本。 1. 正则表达式语法 正则表达式就是记录文本规则的代码。 1. 行定位符 行定位符就是用来描述字…

【STM32G431RBTx】备战蓝桥杯嵌入式→决赛试题→第十二届

文章目录 前言一、题目二、模块初始化三、代码实现interrupt.h:interrupt.c:main.h:main.c: 四、完成效果五、总结 前言 无 一、题目 二、模块初始化 1.LCD这里不用配置&#xff0c;直接使用提供的资源包就行 2.ADC:开启ADCsingle-ended 3.LED:开启PC8-15,PD2输出模式就行了…

MySQL高级(InnoDB引擎)

&#xff08;一&#xff09;逻辑存储结构 表空间&#xff08;ibd文件&#xff09;&#xff0c;会生成ibd文件&#xff0c;一个mysql实例可以对应多个表空间&#xff0c;用于存储记录、索引等数据。 段&#xff0c;分为数据段&#xff08;Leaf node segment&#xff09;、索引段…

学弟研一,有几篇SCI论文,做过前端,读博 or 走开发进国企?

同学你好&#xff0c;在正面先抛开选择就业的方面的问题&#xff0c;其实我觉得生活种的很多选择&#xff0c;都可以从以下的几点进行斟酌与考虑&#xff1a; &#xff08;1&#xff09;你最擅长的是哪个方面&#xff1f;&#xff08;2&#xff09;你的兴趣爱好是在哪个方面&am…

从0开始搭建完整UVM工程(可直接用于实际的工程中)、含源码(包括makefile文件)、可直接运行,及详细注释

一、说明 网上的实现uvm工程代码都是抄自张强所著的《UVM实战》,都是讲所有文件放到一个文件夹,且不涉及到实际工程中的uvm结构,以及多文件层级结构,让人理解起来较为困难,本文则将会从0开始教大家如何搭建一个具有实际工程效果的UVM框架: 其对应的书中的框架图如下所示:…

chatgpt赋能Python-pythoncontinue

简介 Python是一种高级编程语言&#xff0c;受到越来越多的人们的欢迎。其中&#xff0c;continue是Python语言中的一个很重要的关键字&#xff0c;它的出现可以很好地帮助程序员们实现自己的编程目标。在本文中&#xff0c;我们将介绍continue关键字&#xff0c;并解释它在Py…

Fourier分析入门——第5章——连续函数

目录 第 5 章 连续函数 5.1 引言 5.2 内积和正交性(Inner products and orthogonality) 5.3 对称性(Symmetry) 5.4 复数值函数 第 5 章 连续函数 5.1 引言 在前面的章节中&#xff0c;我们只考虑了在有限区间 L 上定义的离散函数的Fourier级数模型。此类函数在实验科学…

spring 源码

bean的创建 获取类class 推断构造方法 Autoware 创建一个普通对象 依赖注入 populateBean 把一些属性注入 初始化之前 PostConstruct 注解 初始注入 实际可以用构造方法啊 初始化 initializationBean 1.判断是否有aware接口 invokeAwareMethods 2.执行 applyBeanP…

enq: TM - contention等待事件引起的数据库卡顿分析

用户的数据库系统在2022年5月31日下午17:25至17:45出现严重的锁等待&#xff0c;导致对应的应用程序出现卡顿等情况&#xff0c;业务系统的正常使用受到影响&#xff0c;无法正常办理业务&#xff1b;在此情况下需要排查出锁问题的深层原因&#xff0c;从而从根本上解决问题。 …

【Python psycopg2】零基础也能轻松掌握的学习路线与参考资料

Python psycopg2是一个Python库&#xff0c;在Python中提供了一个连接PostgreSQL数据库的接口。它可以让Python应用程序和PostgreSQL数据库之间进行通信和数据传输。学习Python psycopg2的路线和教程可以在查阅资料和实践中快速入门。 一、学习前置知识 学习Python psycopg2需…

23 memset 的调试

前言 同样是一个 很常用的 glibc 库函数 不管是 用户业务代码 还是 很多类库的代码, 基本上都会用到 内存数据的设置 不过 我们这里是从 具体的实现 来看一下 它的实现 主要是使用 汇编 来进行实现的, 因此 理解需要一定的基础 测试用例 就是简单的使用了一下 memcpy,…

去面试测试开发工程师要做哪些准备?大厂真实面试题汇总

目录 1.黑盒测试和白盒测试的区别特点和方法。 2.单元测试、集成测试、系统测试、验收测试、回归测试 3.集成测试和系统测试的区别和应用场景 4.α测试、β测试&#xff0c;以及它们的区别 5.给你一个字符串&#xff0c;你怎么判断是不是ip地址&#xff1f;手写这段代码&…

大数据之RDD的算子分类

文章目录 前言一、RDD的算子分类二、Transformation转换算子三、Action动作算子总结 前言 #博学谷IT学习技术支持# 上一篇文章主要讲述了两种RDD的创建方式&#xff0c;本篇文章接着讲RDD的算子及其分类。 一、RDD的算子分类 RDD的算子主要有两种类型&#xff0c;一种是Tran…

docker面试题:docker容器虚拟化与传统虚拟机比较

容器就是将软件打包成标准化单元&#xff0c;以用于开发、交付和部署。 容器镜像是轻量的、可执行的独立软件包 &#xff0c;包含软件运行所需的所有内容&#xff1a;代码、运行时环境、系统工具、系统库和设置。容器化软件在任何环境中都能够始终如一地运行。容器赋予了软件独…

什么是强化学习?强化学习有哪些框架、算法、应用?

什么是强化学习&#xff1f; 强化学习是人工智能领域中的一种学习方式&#xff0c;其核心思想是通过一系列的试错过程&#xff0c;让智能体逐步学习如何在一个复杂的环境中进行最优的决策。这种学习方式的特点在于&#xff0c;智能体需要通过与环境的交互来获取奖励信号&#…

JAVA常用API - 正则表达式

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 目录 文章目录 前言 一&#xff0c;正则表达式是什么&#xff1f; 二&#xff0c;正则表达式符号 三&#xff0c;常用正则表达式组合 四&#xff0c;正则表达…

利用MySQL的binlog恢复误删的数据库

1 查看当前数据库内容并备份数据库 查看数据库信息&#xff1a; 备份数据库&#xff1a; [rootlocalhost ~]# mysqldump -u root -p t > /mnt/t.sql Enter password: [rootlocalhost ~]# ll /mnt/t.sql -rw-r--r-- 1 root root 1771 Aug 25 11:56 /mnt/t.sql2 开启bin…

java-----web项目部署到新服务器以及服务器的部署

目录 一、服务器安装jdk1.8 二、安装mysql5.7 2.1下载mysql 2.2修改root账号密码 2.3设置远程登录 三、项目的部署 3.1导入数据库 3.2将项目打成jar包 3.3项目上传 服务器部署项目的方式&#xff0c;本次以打成jar包的形式讲解&#xff08;以springboot项目为例&#xf…

2023年贵工程团体程序设计赛--部分题解

作者&#xff1a;杨书瑶 单位&#xff1a;贵州工程应用技术学院 本次比赛由大学生程序设计协会(cpa)举办,共计17道题&#xff0c;295分。其中5分题三道&#xff0c;10分题三道&#xff0c;15分题两道&#xff0c;20分题三道&#xff0c;25分题两道&#xff0c;30分题两道…

chatgpt赋能Python-pythonbus

PythonBus: 为Python 开发者量身打造的社区 对于所有Python 开发者而言&#xff0c;PythonBus 是一个非常值得加入的社区平台。该平台汇聚了全球最顶尖的Python 开发者&#xff0c;同时也是一站式排除各种问题并交流经验的平台。在PythonBus&#xff0c;无论你是初学者还是专家…