图论(算法竞赛、蓝桥杯)--Dijkstra算法最短路

1、B站视频链接:D02 最短路 Dijkstra 算法_哔哩哔哩_bilibili

题目链接:【模板】单源最短路径(弱化版) - 洛谷

#include <bits/stdc++.h> 
using namespace std;
#define INF 2147483647
int n,m,s,a,b,c;
const int N=100010;
struct edge{int v,w;};//终点和边权 
vector<edge>e[N];
int d[N],vis[N];void dijkstra(int s){for(int i=0;i<=n;i++){d[i]=INF;//初始化所有点到原点距离为无穷大 }d[s]=0;//到自身距离为0for(int i=1;i<n;i++){//枚举次数n-1次 int u=0;for(int j=1;j<=n;j++){//枚举n个点 if(!vis[j]&&d[j]<d[u])u=j;//找到距离最短的点 }vis[u]=1;//标记当前距离最短的点出圈for(auto ed:e[u]){//枚举当前点的所有邻边 int v=ed.v,w=ed.w;if(d[v]>d[u]+w){//三角形松弛操作 d[v]=d[u]+w;}} } 
}
int main(){cin>>n>>m>>s;for(int i=0;i<m;i++){cin>>a>>b>>c;e[a].push_back({b,c});//a到b边权为c }dijkstra(s);for(int i=1;i<=n;i++){printf("%d ",d[i]);}return 0;
}

#include <bits/stdc++.h> 
using namespace std;
const int N=100010;
int n,m,s,a,b,c;
struct edge{int v,w;};
vector<edge> e[N];
int d[N],vis[N];
void dijkstra(int s){memset(d,0x3f,sizeof d);d[s]=0;priority_queue<pair<int,int>>q;q.push({0,s});while(q.size()){auto t=q.top();q.pop();int u=t.second;if(vis[u])continue;//已经出队的就跳过vis[u]=1;//出队标记for(auto ed:e[u]){int v=ed.v,w=ed.w;if(d[v]>d[u]+w){d[v]=d[u]+w;q.push({-d[v],v});//加上负号大根堆等价于小根堆 }} }
}
int main(){cin>>n>>m>>s;for(int i=0;i<m;i++){cin>>a>>b>>c,e[a].push_back({b,c});}dijkstra(s);for(int i=1;i<=n;i++)printf("%d ",d[i]); return 0;
}

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

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

相关文章

c++学习记录 vector容器—赋值操作

函数原型&#xff1a; vector& operator(const vector& vec); //重载等号操作符assign(beg,end); //将[beg,end)区间中的数据拷贝赋值给本身assign(n,elem); //将n个el…

DAY12_VUE基本用法详细版

目录 0 HBuilderX酷黑主题修改注释颜色1 VUE1.1 VUE介绍1.2 Vue优点1.3 VUE入门案例1.3.1 导入JS文件1.3.2 VUE入门案例 1.4 VUE基本用法1.4.1 v-cloak属性1.4.2 v-text指令1.4.3 v-html指令1.4.4 v-pre指令1.4.5 v-once指令1.4.6 v-model指令1.4.7 MVVM思想 1.5 事件绑定1.5.1…

使用空闲电脑免费搭建一个私人的网盘

如果你也有一台空闲电脑&#xff0c;可以使用它来搭建一个私人的网盘。 这里使用的是飞梦云网盘&#xff1b; 服务端&#xff1a;下载 服务器文件使用hash校验进行储存&#xff0c;实现重复上传的文件秒传功能。 Fuse4Ui&#xff08;虚拟分区工具&#xff09;&#xff1a;下…

算法沉淀——动态规划之回文串问题(上)(leetcode真题剖析)

算法沉淀——动态规划之回文串问题 01.回文子串02.最长回文子串03.分割回文串 IV04.分割回文串 II05.最长回文子序列06.让字符串成为回文串的最少插入次数 01.回文子串 题目链接&#xff1a;https://leetcode.cn/problems/palindromic-substrings/ 给你一个字符串 s &#xf…

Django定时任务之django_apscheduler使用

Django定时任务之django_apscheduler使用 今天在写一个任务需求时需要用到定时任务来做一部分数据处理与优化&#xff0c;于是在了解完现有方法&#xff0c;结合自己需求决定使用django_apscheduler&#xff0c;记录一下过程&#xff0c;有几篇值得参考的文章放在结尾&#xf…

python|闲谈2048小游戏和数组的旋转及翻转和转置

目录 2048 生成数组 n阶方阵 方阵旋转 顺时针旋转 逆时针旋转 mxn矩阵 矩阵旋转 测试代码 测试结果 翻转和转置 2048 《2048》是一款比较流行​的数字游戏​&#xff0c;最早于2014年3月20日发行。原版2048由Gabriele Cirulli首先在GitHub上发布&#xff0c;后被移…

云计算新宠:探索Apache Doris的云原生策略

文章目录 Apache Doris 特性极简架构高效自运维高并发场景支持MPP 执行引擎明细与聚合模型的统一便捷数据接入 Apache Doris 极速 1.0 时代极速列式内存布局向量化的计算框架Cache 亲和度虚函数调用SIMD 指令集 稳定多源 关于 Apache Doris 开源社区基于云原生向量数据库Milvus…

搜维尔科技:CATIA为建筑、基础设施和城市规划提供虚拟孪生力量

超越传统项目交付方法限制的协作 复杂建筑和基础设施项目开发的设计和工程流程需要多个利益相关者和所有项目阶段的密切合作。此外&#xff0c;日益复杂的施工项目要求所有团队都依赖 CATIA 和3D EXPERIENCE 虚拟孪生技术作为“通用语言”&#xff0c;以促进协作并减少阶段之间…

【OneAPI】节假日查询API

OneAPI新接口发布&#xff1a;节假日查询API 可查询指定月份、年份法定节假日及调休情况。 API地址&#xff1a;https://oneapi.coderbox.cn/openapi/public/holiday 请求参数 URL参数 参数名类型必须含义说明datestring否要查询的日期可按年或月查询&#xff0c;支持前缀…

如何获取Cookie??

在学习Servlet的时候&#xff0c;我们便学习过如何获取Cookie&#xff0c;我们来回顾以下吧&#xff01; RestController RequestMapping("/param") public class ParamController {//如何获取CookieRequestMapping("/getCookie")public String getCookie…

[计算机网络]--MAC/ARP/DNS协议

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、认识以…

教育教学论坛期刊投稿发表

《教育教学论坛》杂志是由国家新闻出版总署批准的正规教育类期刊。期刊宗旨是为我国教育发展服务&#xff0c;传播教育教学改革&#xff1b;提高广大教育工作者的教学理论水平与教学质量&#xff1b;是推进新教育、新理念、新方法&#xff0c;展示教育教学领域的新成果&#xf…