P4779 【模板】单源最短路径(标准版)

题目链接

https://www.luogu.org/problemnew/show/P4779

题目描述

给定一个 N个点,M条有向边的带非负权图,请你计算从 S出发,到每个点的距离。

数据保证你能从 S 出发到任意点。

输入输出格式

输入格式:

第一行为三个正整数 N,M,S。 第二行起 M行,每行三个非负整数 \(u_i, v_i, w_i\)表示从 \(u_i\) 到 \(v_i\)有一条权值为 \(w_i\)的边。

输出格式:

输出一行 N个空格分隔的非负整数,表示 S 到每个点的距离。

输入输出样例

输入样例#1:

复制

  1. 4 6 1
  2. 1 2 2
  3. 2 3 2
  4. 2 4 1
  5. 1 3 5
  6. 3 4 3
  7. 1 4 4

输出样例#1:

复制

  1. 0 2 4 3

说明

\(\large1≤N≤100000\)

\(\large1≤M≤200000\)

\(\large S=1\)

\(\large1≤ui,vi≤N\)

$\large0≤wi≤10^9 $

\(\large0≤\sum w_i \leq 10 ^ 9\)

题解

最短路模板题,好久没做图啦,最近一直在做路,竟然存了双向边。。。

代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define ll long long
  4. #define N 100050
  5. #define M 200050
  6. int n,m,dis[N];
  7. int tot,last[N];
  8. struct Edge{int from,to,val,s;}edges[M];
  9. template<typename T>void read(T&x)
  10. {
  11. ll k=0; char c=getchar();
  12. x=0;
  13. while(!isdigit(c)&&c!=EOF)k^=c=='-',c=getchar();
  14. if (c==EOF)exit(0);
  15. while(isdigit(c))x=x*10+c-'0',c=getchar();
  16. x=k?-x:x;
  17. }
  18. void read_char(char &c)
  19. {while(!isalpha(c=getchar())&&c!=EOF);}
  20. void AddEdge(int x,int y,int z)
  21. {
  22. edges[++tot]=Edge{x,y,z,last[x]};
  23. last[x]=tot;
  24. }
  25. void dijkstra(int qd)
  26. {
  27. struct HeapNode
  28. {
  29. int id,val;
  30. bool operator <(const HeapNode&b)const
  31. {return val>b.val;}
  32. };
  33. priority_queue<HeapNode>Q;
  34. memset(dis,127,sizeof(dis));
  35. dis[qd]=0;
  36. Q.push(HeapNode{qd,0});
  37. while(!Q.empty())
  38. {
  39. int u=Q.top().id,d=Q.top().val;
  40. Q.pop();
  41. if (d!=dis[u])continue;
  42. for(int i=last[u];i;i=edges[i].s)
  43. {
  44. Edge &e=edges[i];
  45. if (dis[e.to]-dis[u]>e.val)
  46. {
  47. dis[e.to]=dis[u]+e.val;
  48. Q.push(HeapNode{e.to,dis[e.to]});
  49. }
  50. }
  51. }
  52. }
  53. int main()
  54. {
  55. #ifndef ONLINE_JUDGE
  56. freopen("aa.in","r",stdin);
  57. #endif
  58. int qd;
  59. read(n); read(m); read(qd);
  60. for(int i=1;i<=m;i++)
  61. {
  62. int x,y,z;
  63. read(x); read(y); read(z);
  64. AddEdge(x,y,z);
  65. }
  66. dijkstra(qd);
  67. for(int i=1;i<=n;i++)printf("%d ",dis[i]);
  68. }

洛谷P4779 【模板】单源最短路径的更多相关文章

  1. 【洛谷 p3371】模板-单源最短路径(图论)

    题目:给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 解法:spfa算法. 1 #include<cstdio> 2 #include<cstdlib> 3 #in ...

  2. [模板]单源最短路径(Dijkstra)

    如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 主要还是再打一遍最短路,这种算法我用的不多... #include<bits/stdc++.h> using namesp ...

  3. 洛谷 P4779【模板】单源最短路径(标准版)

    洛谷 P4779[模板]单源最短路径(标准版) 题目背景 2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 然后呢? 10 ...

  4. 洛谷 P4779 【模板】单源最短路径(标准版) 题解

    P4779 [模板]单源最短路径(标准版) 题目背景 2018 年 7 月 19 日,某位同学在 NOI Day 1 T1 归程 一题里非常熟练地使用了一个广为人知的算法求最短路. 然后呢? 100 ...

  5. 洛谷 P3371 【模板】单源最短路径(弱化版) 题解

    P3371 [模板]单源最短路径(弱化版) 题目背景 本题测试数据为随机数据,在考试中可能会出现构造数据让SPFA不通过,如有需要请移步 P4779. 题目描述 如题,给出一个有向图,请输出从某一点出 ...

  6. 洛谷P3371 【模板】单源最短路径

    P3371 [模板]单源最短路径 282通过 1.1K提交 题目提供者HansBug 标签 难度普及/提高- 提交  讨论  题解 最新讨论 不萌也是新,老司机求带 求看,spfa跑模板40分 为什么 ...

  7. 洛谷 P3371 【模板】单源最短路径

    P3371 [模板]单源最短路径 题目描述 如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 输入输出格式 输入格式: 第一行包含三个整数N.M.S,分别表示点的个数.有向边的个数.出 ...

  8. 【原创】洛谷 LUOGU P3371 【模板】单源最短路径

    P3371 [模板]单源最短路径 题目描述 如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 输入输出格式 输入格式: 第一行包含三个整数N.M.S,分别表示点的个数.有向边的个数.出 ...

  9. P4779 【模板】单源最短路径(标准版)

    P4779 [模板]单源最短路径(标准版) 求单源最短路, 输出距离 Solution \(nlogn\) 堆优化 \(Djs\) Code #include<iostream> #inc ...

随机推荐

  1. java 构造方法中super()和this()

    1)super(参数):调用基类中的某一个构造函数(应该为构造函数中的第一条语句) 2)this(参数):调用本类中另一种形成的构造函数(应该为构造函数中的第一条语句) 3)super: 它引用当前对 ...

  2. Try-Catch-Finally代码块中的return

    测试类的原型是这样子的 public class TryCatchFinallyToReturn { public static void main(String[] args) { System.o ...

  3. [python]字典的直接赋值、浅拷贝和深拷贝解析

    1.赋值引用 b = a: a 和 b 都指向同一个对象. 2.浅拷贝 b = a.copy():  a 和 b父对象是一个独立的对象,但他们的子对象还是指向统一对象(是引用). 3.深拷贝 b = ...

  4. SpringBoot使用Undertow做服务器

    说明 undertow,jetty和tomcat可以说是javaweb项目当下最火的三款服务器,tomcat是apache下的一款重量级的服务器,不用多说历史悠久,经得起实践的考验.然而:当下微服务兴 ...

  5. 表单 Flask-WTF - 使用

    1 配置 可以使用Flask-WTF来处理web表单,在使用之前要先配置下,打开config.py,编辑添加如下内容 WTF_CSRF_ENABLED = True SECRET_KEY = 'you ...

  6. CISCO实验记录九:NAT地址转换

    1.静态NAT地址转换 #ip nat inside source static 192.168.12.1 192.168.23.4 //将12.1转为23.4 必须精确到主机IP 而不能是某个网段 ...

  7. pwn学习日记Day7 基础知识积累

    知识杂项 strncpy(char s1,const char s2,int n); 其中有三个参数分别表示目标字符串s1,源字符串s2,拷贝长度.意思是将s2指向的字符串的前n个长度的字符放到s1指 ...

  8. Tensorflow使用训练好的模型进行测试,发现计算速度越来越慢

    实验时要对多个NN模型进行对比,依次加载直到第8个模型时,发现运行速度明显变慢而且电脑开始卡顿,查看内存占用90+%. 原因:使用过的NN模型还会保存在内存,继续加载一方面使新模型加载特别特别慢,另一 ...

  9. OpenCL使用CL_MEM_USE_HOST_PTR存储器对象属性与存储器映射

    随着OpenCL的普及,现在有越来越多的移动设备以及平板.超级本等都支持OpenCL异构计算.而这些设备与桌面计算机.服务器相比而言性能不是占主要因素的,反而能耗更受人关注.因此,这些移动设备上的GP ...

  10. 【转】【很全很新】C3P0 连接池和 DBUtils 配合事务使用总结

    [转]https://blog.csdn.net/guozhaohui628/article/details/84793028 很久没用原生连接池,最近想写个小功能,结果发现很多地方不太懂,然后网上搜 ...