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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Vijos——T 1082 丛林探险

發布時間:2024/4/17 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vijos——T 1082 丛林探险 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

https://vijos.org/p/1082

描述

東非大裂谷中有一片神秘的叢林,是全世界探險家的樂園,著名黃皮膚探險家BB一直想去試試。正好我國科學家2005年4月將首次對東非大裂谷進行科考,BB決定隨科考隊去神秘叢林探險。在出發之前,他搜集了國內外有關神秘叢林探險的資料,并繪制成一張地圖:該地圖上有若干安全點(包括入口點和出口點),并將這些安全點編號為1、2、…、n;如果一個安全點和另一個安全點有一條路直接相通,則用一條邊標示;該圖是一個連通圖(任意兩點間有至少一條路徑),地圖上每條路的長度和走這條路需要耗費的體力都做了標示。

KK行走速度為1,并知道自己體力為K。他想知道根據自己的體力情況能否成功地穿過叢林。

格式

輸入格式

第一行兩個整數n(<=5000) m(<=40000),分別表示地圖上安全點的個數和邊的數目;
第2行至第m+1 行每行4個整數x y c d,x、y表示有直接相聯邊的兩個點的編號,c走這條路需要耗費的體力;d表示邊的長度;(其中150<=c,d<=300)
第m+2行兩個整數s t,分別表示安全的入口點和出口點的編號;
第m+3行一個整數k,表示BB的體力值;(K<10^9)
同一行上的多個數據用空格隔開。

輸出格式

一個整數,如果BB能安全地從如入口穿過叢林到達出口,輸出最短時間,否則輸出-1

樣例1

樣例輸入1

4 5 1 2 2 3 1 3 3 5 1 4 7 10 2 4 4 6 3 4 2 6 1 4 5 Copy

樣例輸出1

11 Copy

限制

各個測試點1s

?

要求輸出最小時間,可以在SPFA判斷時 加一個目前消耗體力<總體力

1 #include <cstdio> 2 #include <queue> 3 4 #define min(a,b) (a<b?a:b) 5 #define INF (1<<30) 6 7 using namespace std; 8 9 const int M(40000+5); 10 const int N(5000+15); 11 int n,m,u,v,ups,dis,s,t,tps; 12 13 int head[N],sumedge; 14 struct Edge 15 { 16 int u,v,wp,wd,nx; 17 Edge(int u=0,int v=0,int nx=0,int wp=0,int wd=0): 18 u(u),v(v),nx(nx),wp(wp),wd(wd){} 19 }edge[M<<1]; 20 void ins(int u,int v,int wp,int wd) 21 { 22 edge[++sumedge]=Edge(u,v,head[u],wp,wd); 23 head[u]=sumedge; 24 } 25 26 queue<int>que; 27 int needp[N],needt[N],inq[N]; 28 void SPFA() 29 { 30 for(int i=1;i<=n;i++) 31 needp[i]=needt[i]=INF; 32 que.push(s);inq[s]=1; 33 needp[s]=0;needt[s]=0; 34 while(!que.empty()) 35 { 36 u=que.front(); 37 que.pop(); 38 inq[u]=0; 39 for(int i=head[u];i;i=edge[i].nx) 40 { 41 v=edge[i].v; 42 if(needt[v]>needt[u]+edge[i].wd&&needp[u]+edge[i].wp<=tps) 43 { 44 needt[v]=needt[u]+edge[i].wd; 45 needp[v]=needp[u]+edge[i].wp; 46 if(!inq[v]) 47 que.push(v),inq[v]=1; 48 } 49 } 50 } 51 } 52 53 int main() 54 { 55 scanf("%d%d",&n,&m); 56 for(int i=1;i<=m;i++) 57 { 58 scanf("%d%d%d%d",&u,&v,&ups,&dis); 59 ins(u,v,ups,dis);ins(v,u,ups,dis); 60 } 61 scanf("%d%d%d",&s,&t,&tps); 62 SPFA(); 63 if(needp[t]==INF) printf("-1"); 64 else printf("%d",needt[t]); 65 return 0; 66 }

?

轉載于:https://www.cnblogs.com/Shy-key/p/6958029.html

總結

以上是生活随笔為你收集整理的Vijos——T 1082 丛林探险的全部內容,希望文章能夠幫你解決所遇到的問題。

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