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

leetcode 743.网络延时时间

思路:迪杰斯特拉最短路径

总结起来其实就两件事:

1.从所给起点开始能不能到达所有点;

2.如果能够到达所有点,那么这个时候需要判断每一个点到源点的最短距离,然后从这些点中求出最大值。

所以用最小路径求解是最划算的选择。

  1. 第一步,选源点到哪个节点近且该节点未被访问过
  2. 第二步,该最近节点被标记访问过
  3. 第三步,更新非访问节点到源点的距离(即更新minDist数组)

这里就是一个模板题,里面有注释,可以细看。

class Solution {
public:int networkDelayTime(vector<vector<int>>& times, int n, int k) {vector<vector<int>>grid(n+1,vector<int>(n+1,INT_MAX));//图vector<bool>st(n+1,false);//每个结点是否被访问到vector<int>minRoad(n+1,INT_MAX);//从源点到i点的最小路径for(int i=0;i<times.size();i++){//构建邻接矩阵int x=times[i][0];int y=times[i][1];int quan=times[i][2];grid[x][y]=quan;}minRoad[k]=0;//源点自身int cur=0;//记录距离源点最近的节点for(int i=1;i<=n;i++){//管理更新次数,因为每一次都有点加进来,距离上会发生变化int mins=INT_MAX;//每次都是最大值,不能放外面。for(int v=1;v<=n;v++){//找最近节点,记录节点数if(!st[v]&&minRoad[v]<=mins){mins=minRoad[v];cur=v;}}st[cur]=1;//遍历到最近节点for(int v=1;v<=n;v++){//更新最小路径值if(!st[v]&&grid[cur][v]!=INT_MAX&&minRoad[cur]+grid[cur][v]<minRoad[v]){minRoad[v]=minRoad[cur]+grid[cur][v];}}}int res=0;for(int i=1;i<=n;i++){if(minRoad[i]==INT_MAX)return -1;else{res=max(res,minRoad[i]);}}return res;}
};

http://www.lryc.cn/news/361653.html

相关文章:

  • MATLAB导入导出Excel的方法|读与写Excel的命令|附例程的github下载链接
  • 【第4章】SpringBoot实战篇之登录优化(含redis使用)
  • 数据结构:详解二叉树(树,二叉树顺序结构,堆的实现与应用,二叉树链式结构,链式二叉树的4种遍历方式)
  • HarmonyOS-9(stage模式)
  • RestTemplate代码内部访问RESTful服务的客户端工具
  • Flutter 中的 SliverLayoutBuilder 小部件:全面指南
  • 家政预约小程序11新增预约
  • AI雷达小程序个人名片系统源码 PHP+MYSQL组合开发 带完整的安装代码包以及搭建教程
  • Kafka生产者消息异步发送并返回发送信息api编写教程
  • WiFi串口服务器与工业路由器:局域网应用的协同之力
  • Unity功能——通过按键设置物体朝左/右旋转(含C#转xlua版)
  • 泛微ecology开发修炼之旅
  • PostgreSQL的视图pg_locks
  • 元宇宙NFG结合IPO线上营销模型合理降税
  • Python打印当前目录下,所有文件名的首字母
  • 程序员应该有什么职业素养?
  • 【PostgreSQL17新特性之-冗余IS [NOT] NULL限定符的处理优化】
  • Flink的简单学习二
  • 如何提高员工的工作主动性?
  • FFmpeg PCM编码为AAC
  • React@16.x(16)Render Props
  • STM32 定时器问题
  • CSS学习笔记目录
  • 随笔-我在武汉一周了
  • Python 爬虫零基础:探索网络数据的神秘世界
  • 微信小程序的view的属性值和用法
  • Python优化、异常处理与性能提升技巧
  • Flink状态State | 大数据技术
  • go语言方法之方法值和方法表达式
  • TDMQ CKafka 版弹性存储能力重磅上线!