图论记录之最短路迪杰斯特拉

简述思想

这个思想能用一句话来概括,精简到的极致:每次找到一个最短距离的点并更新起点到各个点的最短距离
如果要可视化的化,B站搜索Dijksra算法,有视频讲解

代码

这里是Acwing的851题,下面的有注释

import java.util.*;public class Main
{private static int N =510;private static int n,m;private static int[] dist;//存放起点到每个点的最短距离private static int[][] g;//邻接矩阵private static boolean[] st;//若为true表示已经确定了起点到i点的最短距离static Scanner in = new Scanner(System.in);static int dijkstra(){Arrays.fill(dist,100001);dist[1]=0;//从起点到起点是0,这个很好理解// 迭代n次for(int i=0;i<n;i++){int t=-1;for(int j=1;j<=n;j++){/*!st[j]表明j这个点我还没有访问t==-1 表明还在初始状态,初始状态必定进入该if分支dist[j]<dist[t]我找到了一个比上一次的结果的距离更短的一个点*/if(!st[j] &&(t==-1 || dist[j]<dist[t]))t=j;}st[t]=true;//标记节点t为访问状态for(int j=1;j<=n;j++)// 1~t t->j 即先到t,再加上t到j这一段距离,也叫做最后一段距离dist[j]=Math.min(dist[j],dist[t]+g[t][j]);}// 能进入该分支,表明再迭代n次后,没有任何一个点能到达终点n,所以终点不可达,那么返回-1(题目要求的)if(dist[n]==100001)return -1;return dist[n];}public static void main(String[] args){n = in.nextInt();m = in.nextInt();g = new int[n+1][n+1];dist = new int[n+1];st=new boolean[n+1];for(int[] arr:g)//不要写成Integer.MAX_VALUE,由于dist[t]+g[t][j],这个运算操作会溢出Arrays.fill(arr,100001);while(m-->0){int x = in.nextInt();int y = in.nextInt();int z = in.nextInt();//重复边取最小g[x][y] = Math.min(g[x][y],z);}System.out.println(dijkstra());}}

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

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

相关文章

基于OneAPI+ChatGLM3-6B+FastGPT搭建LLM大语言模型知识库问答系统

搭建大语言模型知识库问答系统 部署OneAPI部署一个LLM模型部署嵌入模型部署FastGPT新建FastGPT对话应用新建 FastGPT 知识库应用 部署OneAPI 拉取镜像 docker pull justsong/one-api创建挂载目录 mkdir -p /usr/local/docker/oneapi启动容器 docker run --name one-api -d …

03 React 基础样式控制

在React中&#xff0c;有多种方式可以管理组件的样式&#xff0c;每种方式都有其优劣势。以下是一些常见的样式管理方法以及它们之间的比较&#xff1a; 内联样式&#xff08;Inline Styles&#xff09;&#xff1a; function MyComponent() {const style {color: red,backg…

粘包/半包及解决方案

一、粘包/半包介绍 1&#xff1a;粘包 粘包&#xff08;Packet Concatenation&#xff09;通常发生在基于流式传输协议&#xff08;如 TCP&#xff09;的通信中&#xff0c;因为 TCP 是面向流的传输协议&#xff0c;它不保证数据包的边界&#xff0c;而是将数据视为连续的字节…

C#面:C# 中的预定义特性有哪些

常见的 C# 预定义特性&#xff1a; [Obsolete]&#xff1a;用于标记已过时的代码或方法。当使用被标记为[Obsolete]的代码时&#xff0c;编译器会发出警告或错误。 [Serializable]&#xff1a;用于标记类&#xff0c;表示该类的对象可以被序列化为字节流&#xff0c;以便在网…

机器学习:处理jira工单的分类问题

如何根据jira工单的category、reporter自动找到处理它的组呢?这是一个利用机器学习中knn算法的小实践. 目录 Knn算法 数据 示例 分割数据 选择Neighbors knn的优缺点 机器学习是一种技术,它的目的是给机器学习能力,让它们可以根据数据自己做决定,所以对于训练…

密码学及其应用1 —— 密码学概述

1 密码学的基本概念 1.1 网络安全的定义 网络安全是网络领域的一个专业领域&#xff0c;它涵盖了在基础计算机网络基础设施中所采取的措施、网络管理员为保护网络及网络可访问资源免受未授权访问而采纳的政策&#xff0c;以及对其有效性&#xff08;或无效性&#xff09;的持续…

2024年2月线上助听器综合电商(京东天猫淘宝)热销排行榜

鲸参谋监测的综合电商平台&#xff08;京东天猫淘宝&#xff09;2月份助听器品牌销量销额排行榜已揭晓&#xff01; 根据鲸参谋电商大数据显示&#xff0c;2月助听器在综合电商平台销量约为19万&#xff0c;环比上个月下滑了2%&#xff0c;同比去年下滑了25%&#xff1b;销售额…

基于nodejs+vue发艺美发店管理系统python-flask-django-php

系统根据现有的管理模块进行开发和扩展&#xff0c;采用面向对象的开发的思想和结构化的开发方法对发艺美发店管理的现状进行系统调查。采用结构化的分析设计&#xff0c;该方法要求结合一定的图表&#xff0c;在模块化的基础上进行系统的开发工作。在设计中采用“自下而上”的…

javaSwing愤怒的小鸟游戏

一、简介 游戏名称是“愤怒的小鸟”&#xff0c;英文称为“AngryBird”。 “愤怒的小鸟”是著名游戏公司Rovio偶然间开发出来的益智游戏&#xff0c;从2009年12月上市到iOS。&#xff0c;讲述了鸟类和猪因为猪偷鸟蛋反生的一系列故事。游戏的类型版本是横向版本的水平视角&…

6、运行时数据区

Java虚拟机在运行Java程序过程中管理的内存区域&#xff0c;称之为运行时数据区。《Java虚拟机规范》中规定了每一部分的作用。 3.1 程序计数器 程序计数器&#xff08;Program Counter Register&#xff09;也叫PC寄存器&#xff0c;每个线程会通过程序计数器记录当前要执行的…

opencv各个模块介绍(1)

Core 模块&#xff1a;核心模块&#xff0c;提供了基本的数据结构和功能。 常用的核心函数&#xff1a; cv::Mat&#xff1a;表示多维数组的数据结构&#xff0c;是OpenCV中最常用的类之一&#xff0c;用于存储图像数据和进行矩阵运算。 cv::Scalar&#xff1a;用于表示多通道…

网络分层协议和应用模型

分层模型 五层网络模型 MAC地址跟IP地址的区别&#xff1a;MAC地址是唯一的&#xff0c;相当于每个人的指纹&#xff0c;出生时就是唯一的&#xff1b;IP地址就相当于是你当前的住址&#xff0c;是会发生变化的&#xff0c;但是是动态唯一的。 应用层协议 URL URL&#xff…

node.js 常用命令71条详解

一、Node.js 常用的命令包括&#xff1a; node 某个js文件&#xff1a;调用 Node.js 程序&#xff0c;运行指定的 JavaScript 文件。例如&#xff0c;如果你有一个名为 app.js 的文件&#xff0c;你可以使用 node app.js 来运行它。npm install&#xff1a;用于安装 Node.js 项…

web渗透测试漏洞流程:红队目标信息收集之资产搜索引擎收集

web渗透测试漏洞流程 渗透测试信息收集---域名信息收集1.域名信息的科普1.1 域名的概念1.2 后缀分类1.3 多重域名的关系1.4 域名收集的作用1.5 DNS解析原理1.6 域名解析记录2. 域名信息的收集的方法2.1 基础方法-搜索引擎语法2.1.1 Google搜索引擎2.1.1.1 Google语法的基本使用…

基于Colab训练的yolov4-tiny自定义数据集(可用于OpenCV For Unity)

参考资料文档和视频。 1.打开文档,点击【文件】【在云端硬盘中保存一份副本】,即将文档复制到自己云端硬盘。 2.打开该文件,按文中提示进行。 【代码执行程序】【更改运行时类型】修改运行时为GPU(免费的GPU不好用,收费的好用,某宝上几十元就可用一个月) 步骤1) !git…

如何调用occtproxy放入自己的wpf文件

1.创建一个wpf程序 2.添加项目occtproxy.vcxproj 3.把该项目配置类型设为dll 4.添加引用 5.报错显示&#xff0c;这是因为还没有生成dll 6.把occtproxy设为启动项目运行&#xff0c;设定输出目录在该目录下&#xff0c;生成dll 7.再运行&#xff0c;即可

一文整合工厂模式、模板模式、策略模式

为什么使用设计模式 今天终于有时间系统的整理一下这几个设计模式了&#xff0c; 这几个真是最常用的&#xff0c;用好了它们&#xff0c;你就在也不用一大堆的if else 了。能更好的处理大量的代码冗余问题。 在我们的实际开发中&#xff0c;肯定会有这样的场景&#xff1a;我…

2024年云仓酒庄新动态:铸就新篇章

原标题&#xff1a;刘总出席成都糖酒会&#xff1a;信任铸就云仓酒庄新篇章&#xff0c;共襄盛举展未来近日&#xff0c;备受瞩目的成都糖酒会盛大开幕&#xff0c;吸引了来自全国各地的业界精英和代表。在这场盛大的行业盛会上&#xff0c;云仓酒庄的刘总亲临现场。 现场&…

以XX大学校园为例的智慧能源管理系统建设方案【能源物联网+智能微电网数字校园、节能校园、低碳校园】

建设背景 贯彻落实《中共中央 国务院关于完整准确全面贯彻新发展理念做好碳达峰碳中和工作的意见》和《国务院关于印发2030年前碳达峰行动方案的通知》要求&#xff0c;把绿色低碳发展纳入国民教育体系。 2021年3月26日为推动信息技术与教育教学深度融合&#xff0c;教育部印…

使用SQLAlchemy库进行数据库操作的基本流程[简单示例]

SQLAlchemy ORM&#xff08;Object-Relational Mapping&#xff09;是 SQLAlchemy 库的一部分&#xff0c;它允许开发者通过对象的方式来操作数据库&#xff0c;而不需要直接编写 SQL 语句。ORM 将数据库中的表映射为 Python 类&#xff0c;表中的每一行数据则映射为相应类的对…