2019中山纪念中学夏令营-Day14 图论初步【dijkstra算法求最短路】
Dijkstra是我学会的第一个最短路算法,为什么不先去学SPFA呢?因为我在luogu上翻到了一张比较神奇的图:

关于SPFA
-它死了
以及网上还有各位大佬的经验告诉我:SPFA这玩意很容易被卡。
于是我就决定学习Dijkstra
结构体存边(链式前向星)+优先队列(堆)+Dijkstra求最短路
详细解析都在代码里。
下面附上代码
//2019.08.14 XYYXP第一次写dijkstra最短路算法 于中山纪念中学
//模板题:Luogu P3371,P4779
#include <cstdio>
#include <queue>
#include <algorithm>
#define rr register
using namespace std;
const int inf = ;
int n,m,s,head[],tot,dis[],used[];
//定义全局变量和最大值(inf)
struct Edge{
int nxt,to,length;
}edge[];
//用结构体存边,nxt表示这条边起点连着的上一条边,to表示这条边通往哪个点,length表示边权
struct state {
int val, pos; bool operator < (const state &tmp) const
{
return val > tmp.val;
}
//重载运算符(重载小于号成大于号,用于大根堆变小根堆)
};
//定义一个结构体存点,pos表示当前点编号,val表示当前点到起点的最短路长度
state makestate(int _pos,int _val)
{
state tmp;
tmp.pos=_pos;
tmp.val=_val;
return tmp;
}
//一个结构体函数,新建一个state类型的结构体
void add(int x,int y,int z)
{
tot++;
edge[tot].to=y;
edge[tot].nxt=head[x];
edge[tot].length=z;
head[x]=tot;
}
//加边函数,表示x到y之间有一条权值为z的边
priority_queue <state> heap;
//新建一个优先队列(STL库函数)
void dijkstra(int st)
{
for(rr int i=;i<=n;i++)
dis[i]=inf;
//初始化起点到各个点的最短路为inf
dis[st]=;
heap.push(makestate(st,dis[st]));
//初始化起点,起点入队
while(!heap.empty())
{
int u = heap.top().pos;
heap.pop();
//取出优先队列中最小的点,用来更新最短路
if(used[u])
continue;
used[u]=true;
//判断和标记当前点是否被已经用来更新过
for(rr int i=head[u];i;i=edge[i].nxt)
{
int &v=edge[i].to;
//引用 v=edge[i].to;
if(dis[v] > dis[u]+edge[i].length)
{
dis[v] = dis[u]+edge[i].length;
//更新最短路
heap.push(makestate(v,dis[v]));
//将更新完的最短路入队
}
}
}
} int main()
{
int x,y,z;
scanf("%d %d %d",&n,&m,&s);
for(rr int i=;i<=m;i++)
{
scanf("%d %d %d",&x,&y,&z);
add(x,y,z);
}
//读入并建边
dijkstra(s);
//调用dijkstra算法函数求单源最短路
for(rr int i=;i<=n;i++)
printf("%d ",dis[i]);
//输出起点到各点的最短路
}
The End
2019中山纪念中学夏令营-Day14 图论初步【dijkstra算法求最短路】的更多相关文章
- 2019中山纪念中学夏令营-Day19 数论初步【GCD(最大公约数),素数相关】
关于GCD的一些定理或运用的学习: 1. 2.二进制算法求GCD 思想:使得最后的GCD没有2(提前把2提出来) 代码实现: #include <cstdio> #define int l ...
- 2019中山纪念中学夏令营-Day21[JZOJ]
2019中山纪念中学夏令营-Day21[JZOJ] 提高组(B组模拟赛)Team_B (由于本人太弱,并没有订正完题目) (题解大部分是从官方题解文件上摘来的) 日常膜拜大神:じやゆん蒟蒻 正文部分: ...
- 2019中山纪念中学夏令营-Day20[JZOJ] T1旅游详解
2019中山纪念中学夏令营-Day20[JZOJ] 提高组B组 Team_B组 T1 旅游 Time Limits: 2000 ms Memory Limits: 262144 KB Descrip ...
- 2019中山纪念中学夏令营-Day9[JZOJ](第六次模拟赛)
Begin (题目的排序方式:Unkown其实是按心情排的) 异或:(摘自百度百科) 异或(xor)是一个数学运算符.它应用于逻辑运算.异或的数学符号为“⊕”,计算机符号为“xor”.其运算法则为: ...
- 2019中山纪念中学夏令营-Day12[JZOJ]
Begin (题目的排序方式:题号) 每期新姿势:(今天推荐一位巨佬)Cefola-Kiroxs 推荐知识:namespace的用法(本赛我的代码中将用到) 2019.08.12[NOIP普及组]模拟 ...
- 2019中山纪念中学夏令营-Day4[JZOJ]
Begin (题目的排序方式:难易程度) 什么是对拍: 对拍是一种在写完程序后,验证自己程序是不是正解的比较方便的方法. 实现过程: 对同一道题,再打一个暴力程序,然后用一些大数据等跑暴力程序来进行验 ...
- 2019中山纪念中学夏令营-Day2[JZOJ]
博客的开始,先聊聊代码实现: 每次比赛以后,要有归纳错误的习惯. 错误小结: 1.读入:scanf(“%c”)会读入回车和空格,但cin不会. 2.对于二维数组的输入,不能把m,n搞混了,会引起严重的 ...
- 2019中山纪念中学夏令营-Day1[JZOJ]
T1 题目描述: 1999. Wexley接苹果(apple) (File IO): input:apple.in output:apple.out 时间限制: 1000 ms 空间限制: 1280 ...
- [小结] 中山纪念中学2018暑期训练小结(划掉)(颓废记)-Day10
[小结] 中山纪念中学2018暑期训练小结(划掉)(颓废记)-Day10 各位看众朋友们,你们好,今天是2018年08月14日,星期二,农历七月初四,欢迎阅看今天的颓废联编节目 最近发生的灵异事件有 ...
随机推荐
- java动态生成HTML文件
在eclipse中,用java动态生成html文件. //用于存储html字符串 StringBuilder stringHtml = new StringBuilder(); try{ //打开文件 ...
- IDEA的小技巧:1.Java代码不被识别2.目录下创建的文件夹所显示样式不是文件夹,而是"包"图标样式的问题
在Idea上面一个正常的代码结构是这个样子的,但是有的时候,比如说当我们直接在一个文件夹中随便的创建的时候就会出现一些问题,比如说想让某个地方为代码目录,某个地方为资源目录的时候,直接的创建目录是不成 ...
- LeetCode 82. 删除排序链表中的重复元素 II(Remove Duplicates from Sorted List II)
题目描述 给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字. 示例 1: 输入: 1->2->3->3->4->4->5 输出: ...
- compare across commits online
https://gist.github.com/nevik/5689882 Examples: https://github.com/octocat/Spoon-Knife/compare/ed122 ...
- Oracle 字段监控 ( column monitor)
Oracle 字段监控 ( column monitor) */--> Oracle 字段监控 ( column monitor) Table of Contents 1. 开启与关闭 2. 字 ...
- tensorflow简介与结构介绍
1.知识点 """ tensorflow前端系统:定义程序的图结构,主要是利用一些API实现 tensorflow后端系统:运算图结构 numpy的reshape,在原始 ...
- ASP.Net Core承载外部程序集
故事背景 一般情况下ASP.Net Core项目配置可以直接在appsetting.json中添加,也可以在项目中添加新的配置文件.但如果想和其他项目一起实现配置文件通用呢?我们可以用绝对定位去访 ...
- Setup Python 开发环境和IPython的基本使用
目录 目录 前言 软件准备 Python交互式Shell 为Python Shell添加补全功能 IPython-400 IPython功能和特性基础 可直接使用部分的Bash指令 别名alias语法 ...
- spring mvc路径匹配原则
Ant path 匹配原则 在Spring MVC中经常要用到拦截器,在配置需要要拦截的路径时经常用到<mvc:mapping/>子标签,其有一个path属性,它就是用来指定需要拦截的路径 ...
- 阶段3 3.SpringMVC·_03.SpringMVC常用注解_3 PathVariable注解
请求地址都一样,根据不同的请求方式,最终让不同的方法去执行.这就是restfull的风格 如果有两个查询都是get的.那么当前访问 满足条件的就是两个. 用一个占位符 {id} 演示PathVaria ...