AcWing 850. Dijkstra求最短路 II

Problem: AcWing 850. Dijkstra求最短路 II

文章目录

  • 思路
  • 解题方法
  • 复杂度
  • Code

思路

这是一个经典的 Dijkstra 算法问题,我们需要找到从点 1 到点 n 的最短路径。Dijkstra 算法是一种贪心算法,它总是选择当前未访问过的节点中距离最短的一个,然后更新其相邻节点的距离。

解题方法

我们使用优先队列(Java 中的 PriorityQueue)来实现 Dijkstra 算法。优先队列可以在 O(logn) 的时间复杂度内插入和删除元素,且总是保持队列头部元素是优先级最高(距离最短)的元素。首先,我们初始化所有节点的距离为无穷大(Integer.MAX_VALUE),然后将起点(节点 1)的距离设为 0,并将其加入优先队列。然后,我们开始主循环,每次从优先队列中取出一个距离最短的节点,然后遍历其所有相邻节点,如果通过当前节点到达相邻节点的距离小于相邻节点当前的距离,就更新相邻节点的距离,并将其加入优先队列。重复这个过程,直到优先队列为空。

复杂度

时间复杂度:

O ( m l o g m ) O(mlogm) O(mlogm),其中 m 是边的数量。这是因为每条边都会被插入优先队列一次。

空间复杂度:

O ( n + m ) O(n + m) O(n+m),其中 n 是节点的数量,m 是边的数量。这是因为我们需要存储每个节点的距离(需要 O ( n ) O(n) O(n) 的空间),以及图的邻接表表示(需要 O ( m ) O(m) O(m) 的空间)。

Code

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.StreamTokenizer;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.PriorityQueue;public class Main {static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static StreamTokenizer sr = new StreamTokenizer(in);static int MAXN = (int) (1e5 + 10);static int MAXM = (int) (1e5 + 10);static int[] distance = new int[MAXN];static boolean[] vis = new boolean[MAXN];static ArrayList<ArrayList<int[]>> graph = new ArrayList<>();static PriorityQueue<int[]> heap = new PriorityQueue<>((a, b) -> a[1] - b[1]);static int n, m;public static void main(String[] args) throws IOException {n = nextInt();m = nextInt();build();for (int i = 0, u, v, w; i < m; i++) {u = nextInt();v = nextInt();w = nextInt();graph.get(u).add(new int[] { v, w });}distance[1] = 0;heap.add(new int[] { 1, 0 });while (!heap.isEmpty()) {int u = heap.poll()[0];if (vis[u]) {continue;}vis[u] = true;for (int[] edge : graph.get(u)) {int v = edge[0];int w = edge[1];if (!vis[v] && distance[u] + w < distance[v]) {distance[v] = distance[u] + w;heap.add(new int[] { v, distance[v] });}}}out.println(distance[n] == Integer.MAX_VALUE ? -1 : distance[n]);out.flush();}private static void build() {// TODO Auto-generated method stubgraph.clear();for (int i = 0; i <= n; i++) {graph.add(new ArrayList<>());}heap.clear();Arrays.fill(vis, false);Arrays.fill(distance, Integer.MAX_VALUE);}static int nextInt() throws IOException {sr.nextToken();return (int) sr.nval;}}

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

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

相关文章

什么是Boot Loader?为什么需要Boot Loader?

2024年5月4日&#xff0c;周六下午 什么是Boot Loader 引导加载程序&#xff08;Boot Loader&#xff09;是一种软件&#xff0c;位于计算机系统的启动过程中&#xff0c;其主要功能是在系统上电后负责引导加载操作系统内核。Boot Loader通常存储在计算机系统的固化存储设备&a…

代码随想录算法训练营第14天 | 144. 二叉树的前序遍历 | 145. 二叉树的后序遍历 | 94. 二叉树的中序遍历

144. 二叉树的前序遍历 解1: 递归 void preorder(struct TreeNode* root, int *array, int *idx) {if (root ! NULL) {array[(*idx)] root->val;preorder(root->left, array, idx);preorder(root->right, array, idx);} }int* preorderTraversal(struct TreeNode* …

【代码随想录】day49

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、121. 买卖股票的最佳时机二、122.买卖股票的最佳时机II 一、121. 买卖股票的最佳时机 class Solution { public:int maxProfit(vector<int>& prices…

Qt QImageWriter类介绍

1.简介 QImageWriter 用于写入图像文件的类。它提供了将 QImage 对象保存到不同图像格式文件的功能&#xff0c;包括但不限于 PNG、JPEG、BMP 等。QImageWriter 可以将图像写入文件&#xff0c;也可以写入任何 QIODevice&#xff0c;如 QByteArray&#xff0c;这使得它非常灵活…

pytorch简单神经网络模型训练

目录 一、导入包 二、数据预处理 三、定义神经网络 四、训练模型和测试模型 五、程序入口 一、导入包 import torch import torch.nn as nn import torch.optim as optim # 导入优化器 from torchvision import datasets, transforms # 导入数据集和数据预处理库 from tor…

python中type,object,class 三者关系

type,object,class 三者关系 在python中&#xff0c;所有类的创建关系遵循&#xff1a; type -> int -> 1 type -> class -> obj例如&#xff1a; a 1 b "abc" print(type(1)) # <class int> 返回对象的类型 print(type(int)) …

基于OpenCv的图像金字塔

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

sql-server--索引

SQL Server提供了五种索引类型&#xff0c;它们分别是 唯一索引 主键索引 聚集索引 &#xff08; Clustered Index &#xff09; 非聚集索引 &#xff08; Nonclustered Index &#xff09; 视图索引 --tb_student表的sno列创建索引 create index ix_sno on tb_student(…

【讲解如何OpenCV入门】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

需求规格说明书编制书(word原件)

1 范围 1.1 系统概述 1.2 文档概述 1.3 术语及缩略语 2 引用文档 3 需求 3.1 要求的状态和方式 3.2 系统能力需求 3.3 系统外部接口需求 3.3.1 管理接口 3.3.2 业务接口 3.4 系统内部接口需求 3.5 系统内部数据需求 3.6 适应性需求 3.7 安全性需求 3.8 保密性需…

SQL语句每日一练十四

1378. 使用唯一标识码替换员工ID 题目 Employees 表&#xff1a; ------------------------ | Column Name | Type | ------------------------ | id | int | | name | varchar | ------------------------ 在 SQL 中&#xff0c;id 是这张表的…

GiantPandaCV | FasterTransformer Decoding 源码分析(二)-Decoder框架介绍

本文来源公众号“GiantPandaCV”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;FasterTransformer Decoding 源码分析(二)-Decoder框架介绍 作者丨进击的Killua 来源丨https://zhuanlan.zhihu.com/p/669303360 编辑丨GiantPand…

【Python编程实践1/3】模块

目录 目标 模块 import ​编辑 代码小结 题目 from...import 随机模块 代码小结 randint函数 骰子大战 choice函数 总结 目标 拧一颗螺丝&#xff0c;只会用到螺丝刀&#xff1b;但是修一台汽车&#xff0c;需要一整套汽修的工具。函数就像螺丝刀&#xff0c;可以帮…

寻找自己的25号底片

今天没啥知识干货昂&#xff0c;就单纯想跟诸君们聊聊题外话。这两天有些事儿挺忙的&#xff0c;所以呢也没时间为大家整理知识&#xff0c;这段时间一直把自己逼得挺紧的&#xff0c;所以也趁这两天给自己放个假&#xff0c;好好休息休息&#xff0c;还望诸君理解。 这两天那…

python项目==一个web项目,配置模板指定文件清洗规则,调用模板规则清洗文件

代码地址 一个小工具。 一个web项目&#xff0c;配置模板指定文件清洗规则&#xff0c;调用模板规则清洗文件 https://github.com/hebian1994/csv-transfer-all 技术栈&#xff1a; SQLite python flask vue3 elementplus 功能介绍&#xff1a; A WEB tool for cleaning…

JavaScript:Web APIs(三)

本篇文章的内容包括&#xff1a; 一&#xff0c;事件流 二&#xff0c;移除事件监听 三&#xff0c;其他事件 四&#xff0c;元素尺寸与位置 一&#xff0c;事件流 事件流是什么呢&#xff1f; 事件流是指事件执行过程中的流动路径。 我们发现&#xff0c;一个完整的事件执行…

AWTK 和 QT 资源占用不完全对比

因为没有开发两个完全一样的应用程序&#xff0c;对比的结果并不是很准确&#xff0c;仅供参考。 对比的程序为&#xff1a; AWTK demoui 演示了 AWTK 常用功能。 QT QDesktop 演示了 QT 常用功能。 运行平台为&#xff1a; i.MX6ULL Linux 1. 可以执行文件大小 1.1 AWTK…

Delta lake with Java--利用spark sql操作数据1

今天要解决的问题是如何使用spark sql 建表&#xff0c;插入数据以及查询数据 1、建立一个类叫 DeltaLakeWithSparkSql1&#xff0c;具体代码如下&#xff0c;例子参考Delta Lake Up & Running第3章内容 import org.apache.spark.sql.SaveMode; import org.apache.spark.…

【JavaScript】let,const 和 var 的区别

作用域&#xff1a; var 声明的变量具有全局作用域和函数作用域&#xff0c;可以跨块访问。let 和 const 声明的变量还具有块级作用域&#xff0c;意味着它们在声明它们的块&#xff08;例如&#xff0c;if 块、for 块、函数块等&#xff09;内可见。&#xff08;之前没有块作用…