题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1333

解题报告:一个图里面有n个点和m条单向边,注意是单向边,然后每条路开a秒关闭b秒,问从s点到t点的最短时间。一个简单的最短路稍微变了一下。

卡了很久就因为没看到边是单向边,无语。可以用队列优化。

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<iostream>
  4. #include<algorithm>
  5. #include<vector>
  6. #include<deque>
  7. using namespace std;
  8. const int maxn = ;
  9. struct node
  10. {
  11. int v,a,b;
  12. int t;
  13. };
  14. vector<node> List[maxn];
  15.  
  16. int ans[maxn];
  17. int visit[maxn],exist[maxn],n,m,s,t;
  18. int main()
  19. {
  20. int kase = ;
  21. while(scanf("%d%d%d%d",&n,&m,&s,&t)!=EOF)
  22. {
  23. for(int i = ;i <= n;++i)
  24. List[i].clear();
  25. int u1,v1,a1,b1,t1;
  26. for(int i = ;i <= m;++i)
  27. {
  28. scanf("%d%d%d%d%d",&u1,&v1,&a1,&b1,&t1);
  29. if(a1 < t1) continue; //不可能通过的路,已经过滤掉了
  30. node t0;
  31. t0.v = v1;
  32. t0.a = a1;
  33. t0.b = b1;
  34. t0.t = t1;
  35. List[u1].push_back(t0);
  36. }
  37. for(int i = ;i <= n;++i)
  38. ans[i] = 0x7fffffff;
  39. memset(visit,,sizeof(visit));
  40. ans[s] = ;
  41. while()
  42. {
  43. int p = -,M = ;
  44. for(int i = ;i <= n;++i)
  45. if(visit[i] == && ans[i] < M)
  46. {
  47. M = ans[i];
  48. p = i;
  49. }
  50. visit[p] = ;
  51. if(p == -) break;
  52. for(int i = ;i < List[p].size();++i)
  53. if(visit[List[p][i].v] == )
  54. {
  55. int lt = ans[p] % (List[p][i].a + List[p][i].b);
  56. if(List[p][i].a - lt >= List[p][i].t)
  57. ans[List[p][i].v] = min(ans[List[p][i].v],ans[p] + List[p][i].t);
  58. else ans[List[p][i].v] = min(ans[List[p][i].v],ans[p] + (List[p][i].a + List[p][i].b - lt + List[p][i].t));
  59. }
  60. }
  61. printf("Case %d: %d\n",kase++,ans[t]);
  62. }
  63. return ;
  64. }

CSU 1333 Funny Car Racing (最短路)的更多相关文章

  1. CSU 1333 Funny Car Racing

    最短路问题稍微复杂了一点,松弛的时候多判断一些条件就可以了.第一次用SPFA写最短路. #include<cstdio> #include<cmath> #include< ...

  2. CSU - 1333 1333: Funny Car Racing(spfa)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1333 这题多了一个限制条件是每一条路都会规律的开放a时间关闭b时间,车子必须在开放的时候进入,在关 ...

  3. Funny Car Racing CSU - 1333 (spfa)

    There is a funny car racing in a city with n junctions and m directed roads. The funny part is: each ...

  4. Funny Car Racing(最短路变形)

    描述 There is a funny car racing in a city with n junctions and m directed roads. The funny part is: e ...

  5. CSU——2161: 漫漫上学路 最短路

    Description 众所周知,CSU(California State)University) 的上课地点距离学生公寓很远,对于爱睡懒觉的小Z来说,每天去上课就成了一件非常头疼的事,如果有早课的话 ...

  6. 【最短路】【数学】CSU 1806 Toll (2016湖南省第十二届大学生计算机程序设计竞赛)

    题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1806 题目大意: N个点M条有向边,给一个时间T(2≤n≤10,1≤m≤n(n-1), ...

  7. 【最短路】【STL】CSU 1808 地铁 (2016湖南省第十二届大学生计算机程序设计竞赛)

    题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1808 题目大意: N个点M条无向边(N,M<=105),每条边属于某一条地铁Ci ...

  8. CSU 1808 - 地铁 - [最短路变形]

    题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1808 Time limit: 5000 ms Memory limit: 13107 ...

  9. csu - 1659 Graph Center(最短路)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1659 题意是找一个图的中心,图的中心定义是某一个点到其他点的最大距离最小,如果有多个排序输出. 注 ...

随机推荐

  1. JAVA jdbc获取数据库连接

    JDBC获取数据库连接的帮助类 import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManage ...

  2. Arcgis 几何网络分析

    ArcGIS:网络分析(转)   由于之前对网络分析的理解有很多问题,所以在网上找了一些资料,这是其中一篇我觉得比较好的,所以就整理了一下,发到网上来,留个底吧,呵呵 注:关于几何网络的建立见前面的& ...

  3. CSS3定位和浮动详解

    本文为大家分享CSS3定位和浮动的基础概念,与使用方法,供大家参考,具体内容如下 一.定位 1. css定位: 改变元素在页面上的位置 2. css定位机制: 普通流: 浮动: 绝对布局: 3. cs ...

  4. PHP 数据库抽象层pdo

    PDO是PHP数据对象(PHP Data Object)的缩写. pdo就是一个"数据库访问抽象层",作用是统一各种数据库的访问接口,能够轻松地在不同数据库之间进行切换,使得数据库 ...

  5. PHP责任链设计模式

    <?php //责任链设计模式 /** * 每个对象,储存着对自己上级的引用, * 如果自己处理不了,交给上一级. */ class board{ protected $power=1; pro ...

  6. BIOS设置第一启动项

    在电脑的Bois中怎样去设置第一启动项.. 对于很多新手朋友来说,BIOS满屏英文,生涩难懂,话说我原来也很排斥BIOS,界面太丑,光看界面就没什么兴趣,更谈不上深入研究,大多数人在电脑城装机的时候都 ...

  7. UDP SOCKET网络通信 C#

    接收端 using System; using System.Net; using System.Net.Sockets; using System.Text; using System.Thread ...

  8. 20145212 实验四《Andoid开发基础》

    20145212 实验四<Andoid开发基础> 实验内容 安装Android Studio 运行安卓AVD模拟器 使用Android运行出模拟手机并显示自己的学号 实验过程 一.安装An ...

  9. iOS后台播放

    ### 音乐后台播放 * .当程序进入后台的时候,开启后台任务 ``` - (void)applicationDidEnterBackground:(UIApplication *) { // 开启后 ...

  10. 64bit upload app store

    Unity将来时:IL2CPP是什么? http://zhuanlan.zhihu.com/indieace/19972689 Unity3D将来时:IL2CPP(下) http://www.game ...