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

day55 代码随想录算法训练营 图论专题9

1 今日打卡dijkstra堆优化版 47. 参加科学大会第六期模拟笔试bellman_ford算法 94. 城市间货物运输 I2 dijkstra堆优化版2.1 思路数据结构准备用邻接表存储图的边信息用优先队列小顶堆快速找到当前距离起点最近的未访问节点用数组记录起点到各节点的最短距离、访问状态。初始化起点到自身的距离设为 0其余节点初始化为无穷大优先队列加入起点距离为 0。核心循环从优先队列取出当前距离起点最近的节点标记为已访问。遍历该节点的所有邻接边更新邻接节点的最短距离若通过当前节点到达邻接节点的路径更短。把更新后的邻接节点加入优先队列继续循环直到队列为空。结果输出若终点距离仍为无穷大说明无法到达否则输出最短距离。2.2 实现代码import java.util.*; // 定义边的类存储邻接顶点和边的权重 class Edge { int to; // 边指向的邻接顶点编号 int val; // 这条边的权重长度 // 构造方法初始化边的指向和权重 Edge(int to, int val) { this.to to; this.val val; } } // 自定义优先队列的比较器按Pair的第二个值距离升序排列小顶堆 class MyComparison implements ComparatorPairInteger, Integer { Override public int compare(PairInteger, Integer lhs, PairInteger, Integer rhs) { // 比较两个Pair的第二个元素距离保证优先队列弹出距离最小的节点 return Integer.compare(lhs.second, rhs.second); } } // 自定义Pair类存储节点编号, 起点到该节点的距离 class PairU, V { public final U first; // 第一个元素节点编号 public final V second; // 第二个元素起点到该节点的距离 // 构造方法初始化Pair的两个元素 public Pair(U first, V second) { this.first first; this.second second; } } public class Main { public static void main(String[] args) { // 1. 输入处理读取图的节点数n和边数m Scanner scanner new Scanner(System.in); int n scanner.nextInt(); // 节点总数节点编号从1到n int m scanner.nextInt(); // 边的总数 // 2. 构建邻接表存储图的边信息grid[i]存储节点i的所有出边 ListListEdge grid new ArrayList(n 1); // 初始化邻接表节点编号从1开始所以初始化n1个空列表 for (int i 0; i n; i) { grid.add(new ArrayList()); } // 3. 读取每条边的信息填充邻接表 for (int i 0; i m; i) { int p1 scanner.nextInt(); // 边的起点 int p2 scanner.nextInt(); // 边的终点 int val scanner.nextInt();// 边的权重 // 向p1的出边列表中添加一条指向p2、权重为val的边 grid.get(p1).add(new Edge(p2, val)); } // 4. 定义起点和终点起点固定为1终点固定为n int start 1; // 最短路径的起点 int end n; // 最短路径的终点 // 5. 初始化最短距离数组minDist[i]表示起点到节点i的最短距离 int[] minDist new int[n 1]; // 初始化为无穷大表示初始时无法到达 Arrays.fill(minDist, Integer.MAX_VALUE); // 6. 初始化访问状态数组visited[i]为true表示节点i已处理完毕 boolean[] visited new boolean[n 1]; // 7. 初始化优先队列存储节点编号, 起点到该节点的距离按距离升序排列 PriorityQueuePairInteger, Integer pq new PriorityQueue(new MyComparison()); // 8. 起点初始化起点到自身的距离为0加入优先队列 pq.add(new Pair(start, 0)); minDist[start] 0; // 9. Dijkstra核心循环处理所有节点 while (!pq.isEmpty()) { // 9.1 取出当前距离起点最近的节点优先队列顶 PairInteger, Integer cur pq.poll(); int curNode cur.first; // 当前节点编号 int curDist cur.second; // 起点到当前节点的距离 // 9.2 如果该节点已处理过直接跳过避免重复处理 if (visited[curNode]) continue; // 9.3 标记该节点为已访问处理完毕最短距离已确定 visited[curNode] true; // 9.4 遍历当前节点的所有出边更新邻接节点的最短距离 for (Edge edge : grid.get(curNode)) { int nextNode edge.to; // 邻接节点编号 int edgeVal edge.val; // 当前边的权重 // 条件邻接节点未访问 起点到当前节点的距离 边权重 起点到邻接节点的当前最短距离 if (!visited[nextNode] minDist[curNode] ! Integer.MAX_VALUE minDist[curNode] edgeVal minDist[nextNode]) { // 更新邻接节点的最短距离 minDist[nextNode] minDist[curNode] edgeVal; // 将更新后的邻接节点加入优先队列可能重复加入但不影响因为已访问的会跳过 pq.add(new Pair(nextNode, minDist[nextNode])); } } } // 10. 输出结果 if (minDist[end] Integer.MAX_VALUE) { // 终点距离仍为无穷大说明无法到达 System.out.println(-1); } else { // 输出起点到终点的最短距离 System.out.println(minDist[end]); } // 关闭扫描器规范写法 scanner.close(); } }3 bell_ford算法3.1 思路数据结构准备用邻接表存储图的边信息用普通队列而非优先队列存储待松弛的节点用数组记录起点到各节点的最短距离、节点是否在队列中避免重复入队。初始化起点到自身的距离设为 0其余节点初始化为无穷大起点加入队列并标记为 “在队列中”。核心循环松弛操作从队列取出节点取消其 “在队列中” 的标记。遍历该节点的所有邻接边若通过当前节点到达邻接节点的路径更短则更新邻接节点的最短距离。若邻接节点不在队列中将其加入队列并标记继续循环直到队列为空。结果输出若终点距离仍为无穷大说明无法到达否则输出最短距离。3.2 实现代码import java.util.*; public class Main { // 定义边的内部类存储边的终点和权重 static class Link { int to; // 边指向的邻接节点编号 int val; // 这条边的权重长度 // 构造方法初始化边的终点和权重 public Link(int to, int val) { this.to to; this.val val; } } public static void main(String[] args) { // 1. 输入处理读取节点数n和边数m Scanner sc new Scanner(System.in); int n sc.nextInt(), m sc.nextInt(); // n节点总数1~nm边总数 // 2. 构建邻接表存储图的边信息map[i]存储节点i的所有出边 ListListLink map new ArrayList(); // 初始化邻接表节点编号从1开始所以初始化n1个空列表 for (int i 0; i n; i) { map.add(new ArrayList()); } // 3. 读取每条边的信息填充邻接表 for (int i 0; i m; i) { int from sc.nextInt(); // 边的起点 int to sc.nextInt(); // 边的终点 int val sc.nextInt(); // 边的权重 // 向起点from的出边列表中添加一条指向to、权重为val的边 map.get(from).add(new Link(to, val)); } // 4. 初始化最短距离数组minDist[i]表示起点(1)到节点i的最短距离 int[] minDist new int[n 1]; // 初始化为无穷大表示初始时无法到达 Arrays.fill(minDist, Integer.MAX_VALUE); minDist[1] 0; // 起点(1)到自身的距离为0 // 5. 初始化队列标记数组isInQueue[i]为true表示节点i已在队列中避免重复入队 boolean[] isInQueue new boolean[n 1]; QueueInteger que new LinkedList(); // 存储待松弛的节点 que.add(1); // 起点加入队列 isInQueue[1] true; // 标记起点在队列中 // 6. SPFA核心循环松弛所有可优化的边 while (!que.isEmpty()) { int cur que.poll(); // 取出队列头部的节点当前待处理节点 isInQueue[cur] false; // 取消该节点的队列标记允许后续重新入队 // 遍历当前节点的所有出边进行松弛操作 for (Link link : map.get(cur)) { int to link.to; // 邻接节点编号 int val link.val; // 当前边的权重 // 松弛条件起点到cur的距离 边权重 起点到to的当前最短距离 // 补充minDist[cur] ! Integer.MAX_VALUE 避免无穷大数值溢出 if (minDist[cur] ! Integer.MAX_VALUE minDist[cur] val minDist[to]) { minDist[to] minDist[cur] val; // 更新最短距离 // 若邻接节点不在队列中加入队列并标记 if (!isInQueue[to]) { que.add(to); isInQueue[to] true; } } } } // 7. 输出结果 if (minDist[n] Integer.MAX_VALUE) { // 终点n的距离仍为无穷大说明无法到达 System.out.println(unconnected); } else { // 输出起点1到终点n的最短距离 System.out.println(minDist[n]); } sc.close(); // 关闭扫描器规范写法 } }

相关文章:

day55 代码随想录算法训练营 图论专题9

1 今日打卡 dijkstra堆优化版 47. 参加科学大会(第六期模拟笔试) bellman_ford算法 94. 城市间货物运输 I 2 dijkstra堆优化版 2.1 思路 数据结构准备:用邻接表存储图的边信息,用优先队列(小顶堆)快速…...

欧盟小额包裹监管趋严低客单模式如何调整才能不亏

新规下的生存之道:跨境小包模式转型指南 近年来,随着全球电子商务的蓬勃发展,跨境小额包裹贸易成为许多中小卖家的主要业务模式。然而,欧盟海关监管政策的持续收紧,正在对这一传统模式构成严峻挑战。增值税&#xff0…...

锂电池测试设备采集到本地数据库的解决方案

锂电池凭借快速充放电、长循环寿命、无记忆效应等众多优势,在数码产品及电动汽车得到大规模应用,带动了电池工业的发展,同时对产品品质、生产稳定性的要求也越来越严格。因此,作为电池质检的重要设备,实现OCV测试设备的…...

关于Linux中的日志问题

Linux嵌入式开发中遇到的一些日志相关问题linux终端通常不刷屏日志我linux明明起了很多应用,也有日志打印,为啥没有任何日志显示,只有一个空终端你看到的终端界面只有空命令行,没有任何应用日志输出,这是Linux 日志输出…...

OpenClaw智能体资料合集全网最全龙虾AI使用手册一人公司AI助手实战指南Agent本地部署保姆级教程

什么是OpenClaw?OpenClaw,昵称“龙虾AI”,这是爆火的AI智能体执行引擎,完全开源完全免费,支持自定义部署和二次开发,支持接入任意大模型(智谱、Kimi、通义等),支持本地部…...

RabbitMQ和RocketMQ,哪个更好?

前言 最近有球友问我:苏三哥,现在一般的项目中的消息中间件,是用RabbitMQ,还是RocketMQ,更好? 这是一个非常常见的问题。 今天这篇文章就专门跟大家一起聊聊这个话题,希望对你会有所帮助。 …...

c++11的列表初始化及其底层原理

在c98中,只允许数组和结构体的元素使用列表进行初始化但是在c11中,可以使用列表对所有的元素进行初始化在使用{}进行初始化的时候,可以添加,也可以不添加int a { 10 }; int b{ 10 }; int* pa new int[4] {0}; int arr[3]{ 1,2,3 }; pair<int, string >{1, "222&qu…...

PC端U盘防复制软件|Windows USB接口权限管控工具

温馨提示&#xff1a;文末有联系方式产品定位&#xff1a;专业级PC端USB存储设备安全管控方案 本工具是一款专为Windows系统设计的轻量化USB接口权限管理软件&#xff0c;适用于企业IT管理员、保密部门及个人办公用户&#xff0c;实现对U盘、移动硬盘、USB光驱等外接存储设备的…...

乐变热更新服务专项测评:破解更新痛点,赋能产品精品化运营

在移动互联网行业&#xff0c;应用与游戏的版本更新始终是开发与运营团队的核心难题&#xff1a;强制大版本更新易造成用户严重流失&#xff0c;非强制更新则会带来多版本并行管理的巨大压力&#xff0c;更新周期长、效率低的痛点长期制约着产品运营。本次测评基于乐变官方发布…...

可道云私有化部署优势解析

可道云为何适合中小型企业及大规模组织进行私有化部署可道云作为一款优秀的企业级私有云盘解决方案&#xff0c;其独特的架构设计和功能特性使其能够同时满足中小型企业和大型组织的多样化需求。以下从多个维度详细分析其适配性。一、灵活的授权模式满足不同规模需求用户规模的…...

Vue中的MVC、MVP、MVVM有什么区别?一篇搞懂前端架构模式

在Vue开发中&#xff0c;我们经常听到MVC、MVP、MVVM这三个架构模式的说法&#xff0c;尤其是MVVM&#xff0c;作为Vue的核心架构&#xff0c;几乎是每个前端开发者必备的知识点。但很多人容易混淆这三者的概念&#xff0c;不清楚它们之间的核心差异&#xff0c;以及为什么Vue会…...

IFN-γ抗体能否破解肿瘤微环境中的剂量悖论?

一、IFN-γ在肿瘤免疫中扮演什么角色&#xff1f;干扰素-γ&#xff08;IFN-γ&#xff09;是一种主要由活化T细胞、自然杀伤细胞及自然杀伤T细胞产生的炎性细胞因子&#xff0c;传统上被认为在抗肿瘤免疫中发挥核心作用。其通过与细胞表面异源二聚体受体&#xff08;IFNGR1/IF…...

告别代码臃肿!Java 基础语法 02:方法定义、调用与实战

&#x1f44b; 你好呀&#xff01;我是正在学习 AI 智能应用开发的学习者。 上一篇我们搞定了 变量、数据类型、运算符&#xff0c;已经能写简单的运算逻辑。 但代码一多就会变得又长又乱、重复度极高 —— 这时候就必须学会Java 方法&#xff01; 方法是 Java 最基础、最重要的…...

ros2简单的案例,一个节点采集图片,一个节点推理

先说一下为什么要学ros2&#xff0c;&#xff1a;首先他的通信非常快,而且可以多语言编程。比如说&#xff0c;如果要采集一张&#xff0c;然后多个模型推理&#xff0c;然后结果汇总&#xff0c;如果就单纯的用python的多线程&#xff0c;多进程&#xff0c;不仅速度慢&#x…...

QClaw 使用教程 亲测体验:腾讯亲儿子版“龙虾”,微信一句话就能远程操控电脑!(附完整截图+0门槛部署)

大家好&#xff0c;我是 BUG猿&#xff0c;专注 AI 大模型本地部署、省钱白嫖、实用工具踩坑的程序员。最近腾讯电脑管家悄然放出了 QClaw&#xff08;官方定位&#xff1a;随时随地&#xff0c;微信一下&#xff0c;QClaw帮你高效干活&#xff09;&#xff0c;直接把火爆的开源…...

2026年必看!水浸传感器选购避坑指南,守护家庭安全

在2026年的今天&#xff0c;随着智能家居与工业自动化程度的不断加深&#xff0c;水浸传感器作为预防泄漏风险的第一道防线&#xff0c;其重要性日益凸显。无论是家庭中的地下室、厨房、阳台&#xff0c;还是数据中心、精密厂房等关键设施&#xff0c;一次未被及时发现的水浸事…...

一个例子快速搞懂净现值(NPV)

场景你现在要开一个小项目&#xff1a;今天立刻投&#xff1a;1000 元1 年后能收回&#xff1a;1200 元银行利率&#xff08;折现率&#xff09;&#xff1a;5%问&#xff1a;这个项目到底赚不赚&#xff1f;值不值得做&#xff1f;我们来算 净现值 NPV。第一步&#xff1a;先算…...

win11配置java环境变量_主要是位置不好找啊_win7_win10好找---AI大模型应用探索0006

在设定画面&#xff0c;设置画面找到&#xff0c;这个可以看到有个系统详细设置可以看到有个环境变量&#xff0c;打开然后找到系统变量&#xff0c;然后&#xff1a;配置 CLASSPATH%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar然后再去配置&#xff1a;JAVA_HOMED:\2026…...

毕设程序java在线作业管理系统 基于Java的智能化作业提交与评阅平台 Java驱动的数字化课业管理与交互系统

毕设程序java在线作业管理系统6u09wm4d &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着教育信息化进程的不断深入&#xff0c;传统纸质作业管理模式已难以满足现代教学的多元…...

Day50:2026年3月18日打卡

一、上机打卡1.1 回形取数1.1.1 题目回形取数就是沿矩阵的边取数&#xff0c;若当前方向上无数可取或已经取过&#xff0c;则左转90度。一开始位于矩阵左上角&#xff0c;方向向下。输入说明&#xff1a;输入第一行是两个不超过200的正整数m, n&#xff0c;表示矩阵的行和列。接…...

K6性能测试及生成Html压测报告

一、引言&#xff1a; k6是一款开源负载测试工具&#xff0c;由Grafana Labs开发维护&#xff0c;专注于现代云环境和微服务架构 的高并发压测。它采用Go语言编写&#xff0c;使用JavaScript(ES6)作为脚本语言。还提到它特别适合CI/CD集成和自动化性能测试。 二、下载安装&am…...

低空运行技术研究报告

检索日期&#xff1a;2026-03-18 检索范围&#xff1a;SCI/EI/中文核心期刊/行业报告/预印本【研究进展】 一、代表性最新研究成果 1. 《A Survey of Security Challenges and Solutions for UAS Traffic Management (UTM) and small Unmanned Aerial Systems (sUAS)》 来源&am…...

面试必杀技:彻底搞懂 JVM 内存模型与区域划分(上篇)

在 Java 面试中&#xff0c;JVM&#xff08;Java 虚拟机&#xff09;是区分中高级开发者的分水岭。很多同学对 JVM 感到恐惧&#xff0c;觉得它只是一堆干巴巴的概念。其实&#xff0c;只要把它当成一个“虚拟的操作系统”&#xff0c;一切就豁然开朗了。 本系列将分为上、中、…...

从“亡羊补牢”到“规则先行”:金仓数据库的主动防御之道

在数字化转型的浪潮中&#xff0c;数据已成为企业的核心资产。然而&#xff0c;SQL注入攻击如同潜伏在阴影中的“不速之客”&#xff0c;时刻威胁着数据库的安全。即使开发团队严守预编译、输入过滤等防线&#xff0c;遗留代码、第三方组件的漏洞或人为疏忽仍可能给攻击者可乘之…...

四六级 | 2026年英语四六级视频课程

2026上半年四六级笔试/口试时间已定 &#x1f4cc; 考试时间 ▪ 笔试&#xff1a;6月13日 ▪ 口试&#xff1a;5月23日—5月24日 &#x1f4cc; 准考证打印 ▪ 口试准考证&#xff1a;5月19日 9:00起 ▪ 笔试准考证&#xff1a;6月5日 9:00起 四六级 | 2026年英语四六级视…...

OpenClaw Windows 10 WSL2 安装与配置指南+飞书接入(使用腾讯云Coding Plan)

文章目录基础环境第一阶段&#xff1a;安装 WSL2 环境1.1 开启 WSL21.2 迁移 WSL2 到非 C 盘&#xff08;推荐&#xff09;1.3 启用 systemd1.4 WSL 固定 DNS1.4.1 关闭 WSL 自动生成 DNS1.4.2 删除 systemd 生成的 resolv.conf1.4.3 创建新的静态 DNS 文件1.4.4 重启 WSL1.4.5…...

20260318_203310_AI大模型之RAG(向量库milvus实现)

介绍概念&#xff1a;RAG 检索增强生成Retrieval-Augmented Generation 打个比方 普通 AI&#xff1a;像闭卷考试&#xff0c;只会脑子里记的东西&#xff0c;容易记错、过时。 RAG AI&#xff1a;像开卷考试&#xff0c;先去翻你给的课本 / 文档&#xff0c;找到相关内容&am…...

固定资产清查别敷衍!账实对不上、资产流失,全是清查没做细

说起企业资产管理&#xff0c;很多人盯着折旧核算&#xff0c;却忽略了最基础的固定资产清查。这项工作看似繁琐&#xff0c;却是堵住资产流失、校准财务数据、规避税务与内控风险的关键一步&#xff0c;不管是中小企业还是大型公司&#xff0c;定期做规范清查&#xff0c;才能…...

选艺术字体AI工具这件事,别只盯出图快慢

在日常门店运营中&#xff0c;活动海报的艺术字体设计需要兼顾效率和后续修改空间。最近一次促销活动&#xff0c;首版物料我选择了千图的AI艺术字体工具&#xff0c;主要看重其AI海报可编辑和同款生成功能——能够让AI先产出风格方向&#xff0c;再进一步用其抠图、放大、消除…...

Edge浏览器 about:blank 问题修复

打开新标签出现 about:blank 空页面 修改-> 修复 Get-AppxPackage MicrosoftEdge | Foreach {Add-AppxPackage -DisableDevelopmentMode -Register "(_.InstallLocation)\AppXManifest.xml"}命令含义解析 这段PowerShell命令的核心作用是重新注册/修复微软Edge…...