速度限制

洛谷链接

题目大意:

在一个城市中,每条道路有限速和长度,通过一条道路的时间为这条道路的长度除以限制的速度,有的道路不知道限速为多少,那么就按现在的速度走这条路,找出从第一个点到目标点的最短时间,输出从起点到终点所经过的点。

解题思路:

一看这道题,不就是最短路径的题,来spfa。但很明显单纯的spfa很难实现,所以我们可以搞出一个二维数组dis[i][j],来计算速度为j时到第i个城市需要花费多少时间,不断用spfa来维护这个数组。并且用两个二维数组pre1[i][j],pre2[i][j]来保存路径,意思是速度为j时,更新了第i个点的第pre1[i][j]个点,并且该点速度为pre2[i][j]。

代码:

 1 #include<queue>
 2 #include<cstdio>
 3 #include<cstring>
 4 #define M 420000
 5 #define N 420
 6 using namespace std;
 7 struct hehe{
 8     int x;
 9     int y;
10     hehe(){};
11     hehe(int xx,int yy){
12         x=xx;
13         y=yy;
14     }
15 };
16 queue<hehe>q;
17 double dis[N][521];
18 int next[M],to[M],v[M],l[M],head[N],num,exist[N][521],pre1[N][521],pre2[N][521],n,m,p;
19 void add(int false_from,int false_to,int false_v,int false_l){
20     next[++num]=head[false_from];
21     to[num]=false_to;
22     v[num]=false_v;
23     l[num]=false_l;
24     head[false_from]=num;
25 }
26 void spfa(){
27     memset(dis,66,sizeof dis);
28     q.push(hehe(1,70));
29     exist[1][70]=1;
30     dis[1][70]=0;
31     while(!q.empty()){
32         hehe u=q.front();
33         q.pop();
34         exist[u.x][u.y]=0;
35         for(int i=head[u.x];i;i=next[i]){
36             if(!v[i]){
37                 if(1.0*l[i]/u.y+dis[u.x][u.y]<dis[to[i]][u.y]){
38                     dis[to[i]][u.y]=1.0*l[i]/u.y+dis[u.x][u.y];
39                     pre1[to[i]][u.y]=u.x;
40                     pre2[to[i]][u.y]=u.y;
41                     if(!exist[to[i]][u.y]){
42                         exist[to[i]][u.y]=1;
43                         q.push(hehe(to[i],u.y));
44                     }
45                 }
46             }
47             else{
48                 if(1.0*l[i]/v[i]+dis[u.x][u.y]<dis[to[i]][v[i]]){
49                     dis[to[i]][v[i]]=1.0*l[i]/v[i]+dis[u.x][u.y];
50                     pre1[to[i]][v[i]]=u.x;
51                     pre2[to[i]][v[i]]=u.y;
52                     if(!exist[to[i]][v[i]]){
53                         exist[to[i]][v[i]]=1;
54                         q.push(hehe(to[i],v[i]));
55                     }
56                 }
57             }
58         }
59     }
60 }
61 void print(int a,int b){
62     if(a!=1)
63         print(pre1[a][b],pre2[a][b]);
64     printf("%d ",a-1);
65 }
66 int main(){
67     scanf("%d%d%d",&n,&m,&p);
68     p++;
69     for(int i=1;i<=m;++i){
70         int a,b,c,d;
71         scanf("%d%d%d%d",&a,&b,&c,&d);
72         add(a+1,b+1,c,d);
73     }
74     spfa();
75     double mmin=1e30;
76     int minn=0;
77     for(int i=1;i<=500;i++)
78         if(mmin>dis[p][i]){
79             mmin=dis[p][i];
80             minn=i;
81         }
82     print(pre1[p][minn],pre2[p][minn]);
83     printf("%d\n",p-1);
84     return 0;
85 }

View Code

转载于:https://www.cnblogs.com/jsawz/p/6835865.html

P1266 速度限制相关推荐

  1. Hacker:编写高级语言脚本可破解各个云盘的下载速度限制

    Hacker:编写高级语言脚本可破解各个云盘的下载速度限制 目录 输出结果 代码 输出结果 代码

  2. Nginx并发数、每秒连接数、下载速度限制,防攻击杀手锏

    Nginx并发数.每秒连接数.下载速度限制,防攻击杀手锏 本文链接:https://blog.csdn.net/slovyz/article/details/54583882 1.限制IP访问频率: ...

  3. 去除迅雷右侧资源信息栏和迅雷广告,以及迅雷的速度限制修改

    去除迅雷右侧资源信息栏和迅雷广告,以及迅雷的速度限制修改 1.找到迅雷安装文件夹(Thunder Network)---Thunder---profile---userconfig然后用记事本打开 2 ...

  4. 伦敦交通局设置较低的速度限制

    伦敦交通局正在削减8英里的道路限速,这是其承诺的一部分,即到2024年在130英里的TfL公路网上完成20英里/小时的速度限制. 伦敦交通局表示,将在伦敦的五条道路上引入新的.较低的速度限制,作为其& ...

  5. For macOS.百度网盘 破解SVIP、下载速度限制~

    For macOS.百度网盘 破解SVIP.下载速度限制~ 是插件的 https://github.com/CodeTips/BaiduNetdiskPlugin-macOS 2019-01-03 让 ...

  6. Linux服务器使用WonderShaper进行网络速度限制

    wondershaper控制你的带宽资源的方式是在每一个接口上限制带宽.这在你与其他人分享你的网络连接的上行带宽时尤为实用. 服务器限速是很必要的手段,某些服务商要求我们的服务器使用速度不可长时间超过 ...

  7. DataX 中流的速度限制

    概述 这里的流的速度限制是指在单位时间窗口内,最多允许指定的单位数据通过.比如我们需要从源端 A 发送 1000 条数据到目的端 B,如果设置的速度限制为最多 100 条每秒,那么理论上需要 10 秒 ...

  8. DNS隧道工具使用 不过其网络传输速度限制较大

    DNS隧道工具使用 http://www.freebuf.com/sectool/112076.html http://netsec.ccert.edu.cn/zhengming/2011/11/01 ...

  9. 87个常用电脑快捷键大全,别让速度限制你的工资,建议收藏一份!

    你还在因为不熟悉电脑快捷键而烦恼吗?不用担心!今天为大家分享87个常用电脑快捷键大全,里面包含了Wind组合键.Ctrl组合键.Alt组合键.Shift组合键.F组合键,种类齐全!学会了这些快捷键,可 ...

最新文章

  1. 智能车竞赛技术报告 | 智能车视觉 - 中南大学 - 中南大学比亚迪午马2021
  2. 欧拉定理扩展欧拉定理(证明)
  3. 工业交换机的外壳设计重要吗?
  4. 重学java基础第十四课:java特性和优势
  5. 第十二期:面试官问你什么是消息队列?把这篇甩给他!
  6. 阿里扔给腾讯一个烫手山芋
  7. 【C++ STL学习之八】逆向迭代器reverse_iterator
  8. 24. yii2 表单赋值 model-load(), model-attributes 方法
  9. 39个seo大师级经典案例
  10. 顾樵数学物理方法_圣彼得堡国立大学硕士研究生:物理与天文学
  11. 三维空间内点到直线的距离计算公式
  12. 软件设计模式与体系结构(入门基础知识)
  13. 网络配置问题Bringing up interface eth0: Device eth0 does not seem to be present, delaying initialization.
  14. tomcat发布网站的三种方式
  15. 大数据时代的“拼图者”
  16. 酒店预订的 响应真的很繁杂
  17. 2020-08《信息资源管理 02378》真卷(独家文字版),圈定章节考点+统计真题分布
  18. 安卓开发(一)快速搭建Android开发环境
  19. 2020年超级计算机排名,2020中国高性能计算机TOP100榜单正式发布
  20. 洛谷 P4859 已经没有什么好害怕的了 解题报告

热门文章

  1. 软件项目报价明细表_BIM必学软件之REVIT
  2. php点击后增加html元素,如何动态生成html元素以及为元素追加属性的方法介绍(附代码)...
  3. 深入浅出讲解C语言#define宏定义应用及使用方法
  4. windows mysql is read only_mysql中Table is read only错误解决方法(转载)
  5. python 用while输出数字金字塔_用Python实现一个Dual Thrust数字货币量化交易策略
  6. python list存储对象_python List 对象
  7. php 转换数组为小写,PHP如何将数组键转换为小写?
  8. java list 取几个字段组装成map_24道Java各类常见问题整理
  9. java 保垒机telnet,开源堡垒机系统Teleport
  10. c++中求解非线性方程组_齐次线性方程组的基础解系的简便算法