题目描述

小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零。可是小A偏偏又有赖床的坏毛病。于是为了保住自己的工资,小A买了一个十分牛B的空间跑路器,每秒钟可以跑2^k千米(k是任意自然数)。当然,这个机器是用longint存的,所以总跑路长度不能超过maxlongint千米。小A的家到公司的路可以看做一个有向图,小A家为点1,公司为点n,每条边长度均为一千米。小A想每天能醒地尽量晚,所以让你帮他算算,他最少需要几秒才能到公司。数据保证1到n至少有一条路径。

输入格式

第一行两个整数n,m,表示点的个数和边的个数。

接下来m行每行两个数字u,v,表示一条u到v的边。

输出格式

一行一个数字,表示到公司的最少秒数。

输入输出样例

输入 #1复制

  1. 4 4
  2. 1 1
  3. 1 2
  4. 2 3
  5. 3 4
输出 #1复制

  1. 1

说明/提示

【样例解释】

1->1->2->3->4,总路径长度为4千米,直接使用一次跑路器即可。

【数据范围】

50%的数据满足最优解路径长度<=1000;

100%的数据满足n<=50,m<=10000,最优解路径长度<=maxlongint。

思路

  由于数据量很小,可以考虑Floyd,而由于空间跳跃的缘故,直接跑Floyd出来的最短路不一定是真正的最短路。

  于是用倍增的思想来维护一下两点间的最短路。

  可以建立一个bool倍增数组 f[i][j][k] 来表示点对 i,j 间可以由空间跳跃一次跳达。

  如何处理出所有的这样的点对。

  可以枚举 K 跑 Floyd。因为是边权小于Maxlongint的,所以在 1 ~ 64 的范围内枚举k就可以了。

  令中转点为 t , 显然如果 i 到 t 是 2^(k-1) 的距离, 且 t 到 k 是 2^(k-1) 的距离,就知道一定有 i -> j 是 2 ^ k 的距离,此时更新 f[i][j][k] 和 dis[i][j] 即可。

CODE

  1. #include <bits/stdc++.h>
  2. #define dbg(x) cout << #x << "=" << x << endl
  3. #define eps 1e-8
  4. #define pi acos(-1.0)
  5.  
  6. using namespace std;
  7. typedef long long LL;
  8.  
  9. template<class T>inline void read(T &res)
  10. {
  11. char c;T flag=;
  12. while((c=getchar())<''||c>'')if(c=='-')flag=-;res=c-'';
  13. while((c=getchar())>=''&&c<='')res=res*+c-'';res*=flag;
  14. }
  15.  
  16. namespace _buff {
  17. const size_t BUFF = << ;
  18. char ibuf[BUFF], *ib = ibuf, *ie = ibuf;
  19. char getc() {
  20. if (ib == ie) {
  21. ib = ibuf;
  22. ie = ibuf + fread(ibuf, , BUFF, stdin);
  23. }
  24. return ib == ie ? - : *ib++;
  25. }
  26. }
  27.  
  28. int qread() {
  29. using namespace _buff;
  30. int ret = ;
  31. bool pos = true;
  32. char c = getc();
  33. for (; (c < '' || c > '') && c != '-'; c = getc()) {
  34. assert(~c);
  35. }
  36. if (c == '-') {
  37. pos = false;
  38. c = getc();
  39. }
  40. for (; c >= '' && c <= ''; c = getc()) {
  41. ret = (ret << ) + (ret << ) + (c ^ );
  42. }
  43. return pos ? ret : -ret;
  44. }
  45.  
  46. const int maxn = 1e4 + ;
  47.  
  48. int n,m;
  49.  
  50. bool f[][][];
  51. int dis[][];
  52.  
  53. void init() {
  54. for ( int i = ; i <= n; ++i ) {
  55. for ( int j = ; j <= n; ++j ) {
  56. if(i == j) {
  57. dis[i][j] = ;
  58. }
  59. else {
  60. dis[i][j] = 0x3f3f3f3f;
  61. }
  62. }
  63. }
  64. }
  65.  
  66. int main()
  67. {
  68. scanf("%d %d",&n, &m);
  69. init();
  70. int u, v;
  71. for ( int i = ; i <= m; ++i ) {
  72. scanf("%d %d",&u, &v);
  73. dis[u][v] = ;
  74. f[u][v][] = ;
  75. }
  76. for (int t = ; t <= ; ++t) {
  77. for (int k = ; k <= n; ++k) {
  78. for (int i = ; i <= n; ++i) {
  79. for (int j = ; j <= n; ++j) {
  80. if(f[i][k][t-] && f[k][j][t-]) {
  81. f[i][j][t] = ;
  82. if(i != j) dis[i][j] = ;
  83. else
  84. dis[i][j] = ;
  85. }
  86. }
  87. }
  88. }
  89. }
  90. for (int k = ; k <= n; ++k) {
  91. for (int i = ; i <= n; ++i) {
  92. for (int j = ; j <= n; ++j) {
  93. dis[i][j] = min(dis[i][j], dis[i][k] + dis[k][j]);
  94. }
  95. }
  96. }
  97. printf("%d\n",dis[][n]);
  98. return ;
  99. }

P1613 跑路【倍增】【最短路】的更多相关文章

  1. 洛谷 P1613 跑路 (倍增 + DP + 最短路)

    题目链接:P1613 跑路 题意 给定包含 \(n\) 个点和 \(m\) 条边的有向图,每条边的长度为 \(1\) 千米.每秒钟可以跑 \(2^k\) 千米,问从点 \(1\) 到点 \(n\) 最 ...

  2. P1613 跑路——倍增思想,floyd

    https://www.luogu.org/problemnew/show/P1613 他有一个跑路机器,每次只能跑2k   (单位)路程,每相邻两个点的路程为1,也就是说如果连边1——>2—— ...

  3. P1613 跑路 倍增思想 + 邻接矩阵

    题意 给定一个有向图,每条边的花费为1.现在有一个空间跑路器,可以走2^k长度的路,只用花1秒的时间.问从1走到n最少的时间.n <= 50, k <= 64. 思路 这道题说是倍增,但是 ...

  4. P1613 跑路(倍增 + floyd)

    https://www.luogu.org/problemnew/show/P1613 思路: 1.读入 2.建图 3.对于每一个点,向距离它 2^k 长度的点连一条长度为 1 的边 4.在新图上跑1 ...

  5. LUOGU P1613 跑路 (倍增floyd)

    解题思路 倍增$floyd$,首先设$f[i][j][k]$表示$i$这个点到$j$的距离能否为$2^k$,初值是如果x,y之间有边,那么$f[x][y][0]=1$.转移方程就是$f[i][j][t ...

  6. 洛谷P1613 跑路(最短路+倍增)

    P1613 跑路 题目描述 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是为了保住自己的工资,小A买了一个十分牛B的 ...

  7. [Luogu P1613]跑路 (DP+倍增+最短路)

    题面 传送门:https://www.luogu.org/problemnew/show/P1613 Solution 挺有意思的一道题. 题面已经挺明显的描述出了这题的主要思想:倍增. 先这样想,我 ...

  8. P1613 跑路(倍增)

    P1613 跑路(倍增) 题目描述 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是为了保住自己的工资,小A买了一个十 ...

  9. 洛谷 P1613 跑路 解题报告

    P1613 跑路 题目描述 小\(A\)的工作不仅繁琐,更有苛刻的规定,要求小\(A\)每天早上在\(6:00\)之前到达公司,否则这个月工资清零.可是小\(A\)偏偏又有赖床的坏毛病.于是为了保住自 ...

  10. 洛谷——P1613 跑路

    P1613 跑路 题目大意: 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是为了保住自己的工资,小A买了一个十分牛B ...

随机推荐

  1. CQOI十二省联考游记

    Day 0 看似稳如老狗的我实则慌得一逼 看了一上午的CRT,一个字没看进去 我反复安慰自己:我才高一,我才高一 但是,明年的联赛会不会跟今年一样高呢? 明年的心态会不会有现在这么好呢? 明年同届的d ...

  2. 如何使用Serilog.AspNetCore记录ASP.NET Core3.0的MVC属性

    这是Serilog系列的第三篇文章. 第1部分-使用Serilog RequestLogging减少日志详细程度 第2部分-使用Serilog记录所选的终结点属性 第3部分-使用Serilog.Asp ...

  3. GitHub Pages 与 Gitee Pages 上的 Jekyll

    GitHub 与 Gitee 提供的 Pages 服务中,均内嵌了 Jekyll 支持(Gitee 还提供了 Hugo 与 Hexo 支持).所谓「支持」,即指这些生成工具挂在云端:你只需要提供原始代 ...

  4. Java并发读书笔记:JMM与重排序

    目录 Java内存模型(JMM) JMM抽象结构 重排序 源码->最终指令序列 编译器重排序 处理器重排序 数据依赖性 as-if-serial happens-before happens-b ...

  5. 读取纯真IP数据库

    #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #include <stdli ...

  6. MPlayer参数使用介绍(部分)(中文)

    文件太长,就不全部转载了,以下是某MPlayer网站的全部详细介绍: http://www.mplayer.org.cn/help_zh.html#%E7%A8%8B%E5%BA%8F%E9%94%9 ...

  7. 免费丨十大IT热门学科在线直播体验课正式来袭,全免费!!!

    一场突如其来的疫情阻挡了人与人之间的接触,在这一系列困难面前,无数勇敢的人们挺身而出,千里驰援,默默承担,用行动践行责任与信念,希望与祖国和家人一道共渡难关. 传智播客作为一家致力于“高精尖”IT科技 ...

  8. js小练习---实现红绿灯

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Codeforces_101498

    A.map统计数量,更新最大值. #include<bits/stdc++.h> using namespace std; int n; map<int,int> mp; in ...

  10. SpringBoot项目版本升级:从1.5.3升级到2.1.8版本

    SpringBoot项目版本升级:从1.5.3升级到2.1.8版本 前言 简单记录一次本人在自己的SpringBoot项目project-template中,把1.5.3版本升级到2.1.8版本时升级 ...