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

LeetCode 2492.两个城市间路径的最小分数:找1所在连通图的最小边(BFS / DFS)

【LetMeFly】2492.两个城市间路径的最小分数:找1所在连通图的最小边(BFS / DFS)

力扣题目链接:https://leetcode.cn/problems/minimum-score-of-a-path-between-two-cities/

给你一个正整数n,表示总共有n个城市,城市从1n编号。给你一个二维数组roads,其中roads[i] = [ai, bi, distancei]表示城市aibi之间有一条双向道路,道路距离为distancei。城市构成的图不一定是连通的。

两个城市之间一条路径的分数定义为这条路径中道路的最小距离。

返回城市1和城市n之间的所有路径的最小分数。

注意:

  • 一条路径指的是两个城市之间的道路序列。
  • 一条路径可以多次包含同一条道路,你也可以沿着路径多次到达城市1和城市n
  • 测试数据保证城市1和城市n之间至少有一条路径。

示例 1:

输入:n = 4, roads = [[1,2,9],[2,3,6],[2,4,5],[1,4,7]]输出:5解释:城市 1 到城市 4 的路径中,分数最小的一条为:1 -> 2 -> 4 。这条路径的分数是 min(9,5) = 5 。 不存在分数更小的路径。

示例 2:

输入:n = 4, roads = [[1,2,2],[1,3,4],[3,4,7]]输出:2解释:城市 1 到城市 4 分数最小的路径是:1 -> 2 -> 1 -> 3 -> 4 。这条路径的分数是 min(2,2,4,7) = 2 。

提示:

  • 2 <= n <= 105
  • 1 <= roads.length <= 105
  • roads[i].length == 3
  • 1 <= ai, bi<= n
  • ai!= bi
  • 1 <= distancei<= 104
  • 不会有重复的边。
  • 城市1和城市n之间至少有一条路径。

解题方法:找1所在连通图的最小边

由于路径可以无限往返,所以其实只要和1联通的路径都可以走。由于1一定和n联通,所以实际上是找和1联通的节点的所有边中,值最小的那条边。

解题方法一:广度优先搜索(BFS)

遍历一遍roads得到邻接表graph,其中graph[i]是所有和节点i相邻的节点;同时得到节点相邻最小路长m,其中m[i]是所有和节点i相邻的路的最短距离。

使用一个队列进行广度优先搜索,初始时把i入队,每出队一个节点就更新答案最小值,并把其相邻未入队过的节点入队。

解题方法二:深度优先搜索(DFS)

遍历一遍roads得到邻接表graph,其中graph[i]是所有和节点i相邻的(节点, 路的距离)

从节点i开始深度优先搜索,遍历每一条与i相邻的路并更新答案最小值,若某条路上与i相邻的节点还未遍历过则递归。

时空复杂度分析

  • 时间复杂度O ( n ) O(n)O(n)
  • 空间复杂度O ( n ) O(n)O(n)

AC代码

C++ —— BFS
/* * @LastEditTime: 2026-07-04 10:58:26 */#ifdef_DEBUG#include"_[1,2]toVector.h"#endifclassSolution{public:intminScore(intn,vector<vector<int>>&roads){vector<vector<int>>graph(n+1);vector<int>m(n+1,100000);for(vector<int>&road:roads){graph[road[0]].push_back(road[1]);graph[road[1]].push_back(road[0]);m[road[0]]=min(m[road[0]],road[2]);m[road[1]]=min(m[road[1]],road[2]);}intans=100000;vector<bool>visited(n+1);queue<int>q;q.push(1);visited[1]=true;while(q.size()){inta=q.front();q.pop();for(intb:graph[a]){if(!visited[b]){visited[b]=true;q.push(b);ans=min(ans,m[b]);}}}returnans;}};
C++ —— DFS
/* * @LastEditTime: 2026-07-04 11:02:17 */classSolution{private:intans;vector<bool>visited;vector<vector<pair<int,int>>>graph;voiddfs(intfrom){visited[from]=true;for(auto[to,dis]:graph[from]){ans=min(ans,dis);if(!visited[to]){dfs(to);}}}public:intminScore(intn,vector<vector<int>>&roads){visited=vector<bool>(n+1);graph=vector<vector<pair<int,int>>>(n+1);for(vector<int>&road:roads){graph[road[0]].push_back({road[1],road[2]});graph[road[1]].push_back({road[0],road[2]});}ans=100000;dfs(1);returnans;}};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

http://www.jsqmd.com/news/1126553/

相关文章:

  • 抖音批量下载工具终极指南:3分钟掌握无水印视频批量保存技巧
  • 如何高效管理macOS窗口:DockDoor专业窗口预览与切换工具完全指南
  • Ender3V2S1:给Ender 3打印机刷的专业固件
  • 抖音下载器完整指南:3分钟掌握无水印批量下载与智能管理技巧
  • 2025年最强大的微信小程序反编译工具:Unveilr完全使用指南
  • 抖音批量下载器技术解析:从单机工具到企业级内容管理系统的演进
  • Thorium浏览器:终极性能优化的Chromium分支实战指南
  • 2026年毕业季AI论文工具选购指南:五款主流产品横评与推荐
  • OpenCore Legacy Patcher终极指南:让老款Mac运行最新macOS的完整教程
  • 在数据分析中,如何评估分类模型的准确性?常用的评估指标有哪些?
  • 【Hermes入门11讲】第二讲:第一次对话——CLI界面完全指南
  • 如何在循环中使用break和continue语句?
  • 分享一个超简单的蛋糕做法
  • 3种方法解决Beyond Compare 5评估错误:RSA密钥生成完整指南
  • 刚需装修别踩坑!不同预算装饰公司怎么挑?
  • 大气层1.7.1整合包系统稳定版:Nintendo Switch终极自定义固件完全指南
  • AI驱动的Windows提权攻击:从内核漏洞到自动化攻防的范式转移
  • 指纹浏览器环境异常排查:Fingerprint、Profile、Proxy、Session 和 Task Log 怎么看
  • 【响应式】框架初识与理解
  • 终极城通网盘加速指南:免费解锁10倍下载速度的完整教程
  • faster-whisper:语音转文字,快 4 倍
  • Windows屏幕标注终极指南:用ppInk让远程协作像在白板上写字一样简单
  • 真人克隆口播小程序开发全攻略:AI数字人系统源码架构解析
  • 基于Dify工作流与MCP协议构建企业级AI智能副驾实战指南
  • 3分钟掌握抖音下载神器:免费工具助你批量保存视频与直播回放
  • QKeyMapper:Windows平台终极按键映射神器,让手柄玩转所有PC游戏
  • 从团购内卷到 AI 搜索:生成式引擎优化 (GEO) 底层技术拆解与本地实体落地选型指南
  • sklearn KMeans 聚类评估实战:3大指标对比与Seeds数据集可视化
  • OpenCore Legacy Patcher完整教程:4步让老Mac重获新生
  • WorkshopDL终极指南:一站式跨平台Steam创意工坊下载解决方案