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日,星期二,农历七月初四,欢迎阅看今天的颓废联编节目 最近发生的灵异事件有 ...
随机推荐
- 一、基本的bash shell命令(基于Ubuntu实现)
一.基本的bash shell命令(基于Ubuntu实现) /etc/passwd文件包含了所有系统用户账户列表以及每个用户的基本配置信息. man命令 在想要查找的工具的名称前输入man命令,就可以 ...
- 在SpringBoot程序中记录日志
所有的项目都会有日志,日志文件是用于记录系统操作事件的记录文件或文件集合,可分为事件日志和消息日志.具有处理历史数据.诊断问题的追踪以及理解系统的活动等重要作用.这节描述如何用springboot记录 ...
- IP输出 之 ip_output、ip_finish_output、ip_finish_output2
概述 ip_output-设置输出设备和协议,然后经过POST_ROUTING钩子点,最后调用ip_finish_output: ip_finish_output-对skb进行分片判断,需要分片,则分 ...
- SRS之接收推流线程:recv
SrsPublishRecvThread.SrsRecvThread.SrsReusableThread2.SrsThread 之间的关系图 1. recv 线程函数:SrsThread::threa ...
- 微信小程序之地址联动
这就是我们要实现的效果 <view class="consignee"> <!-- consignee 收件人 --> <text>收件人: & ...
- 解决JxBrowser中BrowserView控件覆盖其他控件的办法
https://blog.csdn.net/w815878564/article/details/79699559 JxBrowser是一个基于chromium的Java浏览器组件,同时支持Swing ...
- echarts修改X,Y轴上的颜色
分为2.0和3.0 一.2.0 修改的代码: x轴: xAxis : [ { type : 'category', data : ['<30','30-','40-','50-','60-', ...
- openerp学习笔记 对象调用(创建、修改),用于后台代码创建和更新对象
#服务卡创建,自动更新服务卡为开卡状态 def create(self, cr, uid, values, context=None): values['state'] = '1' ...
- C#调用SQL中存储过程并用DataGridView显示执行结果
//连接数据库 SqlConnection con = new SqlConnection("server=服务器名称;database=数据库名称;user id=登录名;pwd=登录密码 ...
- Apache POI读取Excel
1.pom.xml配置文件 <!-- 配置Apache POI --> <dependency> <groupId>org.apache.poi</group ...