随手一打就是标准的SPFA,默认1号节点为出发点,当然不用 f 判断是否在队里也可以,只是这样更优化一点 void spfa() { int i,x,k; ;i<=n;i++) { d[i]=oo; f[i]=; } d[]=; q.push(); while (!q.empty()) { x=q.front(); q.pop(); f[x]=; for (i=first[x];i;i=next[i]) { k=v[i]; if (d[k]>d[x]+w[i]) { d[k]=d[x]+w[i…
题面 这道题就是标准的堆优化dijkstra: 注意堆优化的dijkstra在出队时判断vis,而不是在更新时判断vis #include <bits/stdc++.h> using namespace std; int n,m,s; struct littlestar{ int to; int nxt; int w; }star[]; ],cnt; void add(int u,int v,int w) { star[++cnt].to=v; star[cnt].w=w; star[cnt]…
题目背景 2018 年7月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 最终,他因此没能与理想的大学达成契约. 小 F 衷心祝愿大家不再重蹈覆辙. 题目描述 给定一个 n 个点,m 条有向边的带非负权图,请你计算从 s 出发,到每个点的距离. 数据保证你能从 s 出发到任意点. 输入格式 第一行为三个正整数 n, m, s. 第二行起 m 行,每行三个非负整数 ui​,vi​,wi​,表示ui​ 到vi​ 有一条权值为wi​ 的有向边…
P4779 [模板]单源最短路径(标准版) 求单源最短路, 输出距离 Solution \(nlogn\) 堆优化 \(Djs\) Code #include<iostream> #include<cstdio> #include<queue> #include<cstring> #include<algorithm> typedef long long LL; using namespace std; LL RD(){ LL out = 0,f…
洛谷 P4779[模板]单源最短路径(标准版) 题目背景 2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 然后呢? 100→60 : Ag→Cu : 最终,他因此没能与理想的大学达成契约. 小 F 衷心祝愿大家不再重蹈覆辙. 题目描述 给定一个 N 个点, M 条有向边的带非负权图,请你计算从 S 出发,到每个点的距离. 数据保证你能从 S 出发到任意点. 输入输出格式 输入格式: 第一行为三个正整数 N, M, S…
P4779 [模板]单源最短路径(标准版) 题目背景 2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 然后呢? 100 \rightarrow 60100→60: Ag \rightarrow CuAg→Cu: 最终,他因此没能与理想的大学达成契约. 小 F 衷心祝愿大家不再重蹈覆辙. 题目描述 给定一个 NN 个点,MM 条有向边的带非负权图,请你计算从 SS 出发,到每个点的距离. 数据保证你能从 SS 出发到任…
单源最短路(dijkstra算法及堆优化) 弱化版题目链接 n^2 dijkstra模板 #include<iostream> #include<cstdio> #include<algorithm> #include<cstring> using namespace std; ]; ]; struct Node{ int to; int w; Node *next; } node[]; Node *head[]; int main() { scanf(&q…
原题链接 https://www.luogu.org/problemnew/show/P4779 若还未食用弱化版的同学请先做这个qwq https://www.luogu.org/problemnew/show/P3371 刚刚做完了弱化版的我,看到了这个标准版 双倍经验美滋滋qwq 把弱化版的SPFA模板打上去,改了下数据范围,提交!悲催的TLE了四个点! 很显然,这个题的数据是卡SPFA的,使得时间复杂度是SPFA最坏的复杂度! 那咋办呢?我们看到了题目中已经说明了没有负权边,那么我们就可…
题目描述 给定一个$n$个点,$m$条有向边的带非负权图,请你计算从$s$出发,到每个点的距离. 数据保证你能从$s$出发到任意点. 输入格式 第一行为三个正整数$n,m,s$. 第二行起$m$行,每行三个非负整数 $u_i, v_i, w_i​$,表示从$u_i​$到$v_i$有一条权值为$w_i$的有向边. 输出格式 输出一行$n$个空格分隔的非负整数,表示$s$到每个点的距离. 输入输出样例 输入 4 6 1 1 2 2 2 3 2 2 4 1 1 3 5 3 4 3 1 4 4 输出 0…
题目背景 2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 然后呢? 100→60 Ag→Cu 最终,他因此没能与理想的大学达成契约. 小 F 衷心祝愿大家不再重蹈覆辙. 题目描述 给定一个 N 个点,M 条有向边的带非负权图,请你计算从 S 出发,到每个点的距离. 数据保证你能从 S 出发到任意点. 输入输出格式 输入格式: 第一行为三个正整数 N,M,S. 第二行起 M 行,每行三个非负整数 ui,vi,wi,表示…