日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P1266 速度限制

發布時間:2023/12/2 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P1266 速度限制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

速度限制

洛谷鏈接

題目大意:

在一個城市中,每條道路有限速和長度,通過一條道路的時間為這條道路的長度除以限制的速度,有的道路不知道限速為多少,那么就按現在的速度走這條路,找出從第一個點到目標點的最短時間,輸出從起點到終點所經過的點。

解題思路:

一看這道題,不就是最短路徑的題,來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 速度限制的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。