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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

[JLOI 2011]飞行路线[USACO 09FEB]Revamping Trails

發(fā)布時間:2025/6/17 编程问答 56 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [JLOI 2011]飞行路线[USACO 09FEB]Revamping Trails 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Description

Alice和Bob現(xiàn)在要乘飛機旅行,他們選擇了一家相對便宜的航空公司。該航空公司一共在n個城市設有業(yè)務,設這些城市分別標記為0到n-1,一共有m種航線,每種航線連接兩個城市,并且航線有一定的價格。Alice和Bob現(xiàn)在要從一個城市沿著航線到達另一個城市,途中可以進行轉機。航空公司對他們這次旅行也推出優(yōu)惠,他們可以免費在最多k種航線上搭乘飛機。那么Alice和Bob這次出行最少花費多少?

Input

數據的第一行有三個整數,n,m,k,分別表示城市數,航線數和免費乘坐次數。 第二行有兩個整數,s,t,分別表示他們出行的起點城市編號和終點城市編號。(0<=s,t<n) 接下來有m行,每行三個整數,a,b,c,表示存在一種航線,能從城市a到達城市b,或從城市b到達城市a,價格為c。(0<=a,b<n,a與b不相等,0<=c<=1000)

Output

只有一行,包含一個整數,為最少花費。

Sample Input

5 6 1
0 4
0 1 5
1 2 5
2 3 5
3 4 5
2 3 3
0 2 100

Sample Output

8

HINT

對于30%的數據,2<=n<=50,1<=m<=300,k=0;

對于50%的數據,2<=n<=600,1<=m<=6000,0<=k<=1;

對于100%的數據,2<=n<=10000,1<=m<=50000,0<=k<=10.

題解

題面放的是$[JLOI 2011]$飛行路線,這兩道題一毛一樣。區(qū)別就是$USACO$的數據$k<=20$,并且$s=1$,$t=n$。

建立分層圖。

$f[u][t]$表示在節(jié)點u時已經免費乘坐t次的最少花費。照樣跑最短路。

枚舉與$u$相連的所有節(jié)點$v$,$w(u,v)$表示權值。
若$t<k$:

$$f[v][t+1]=min(f[v][t+1],f[u][t])$$

對于所有:

$$f[v][t]=min(f[v][t],f[u][t]+w(u,v))$$

由于$USACO$數據范圍大了點,$STL$的優(yōu)先隊列還過不了,手打了個堆$A$了。

(注意代碼中標紅的地方二選一)

1 #include <set> 2 #include <map> 3 #include <ctime> 4 #include <cmath> 5 #include <queue> 6 #include <stack> 7 #include <vector> 8 #include <cstdio> 9 #include <string> 10 #include <cstring> 11 #include <cstdlib> 12 #include <iostream> 13 #include <algorithm> 14 #define LL long long 15 #define Max(a, b) ((a) > (b) ? (a) : (b)) 16 #define Min(a, b) ((a) < (b) ? (a) : (b)) 17 using namespace std; 18 const int INF = ~0u>>1; 19 const int N = 10000; 20 const int M = 50000; 21 22 int s, t; 23 struct tt{ 24 int to, cost, next; 25 }edge[M*2+5]; 26 int path[N+5], top; 27 int n, m, k, u, v, c; 28 struct node{ 29 int cost, u, t; 30 node () {} 31 node (int _cost, int _u, int _t) {cost = _cost, u = _u, t = _t;} 32 bool operator < (const node &b) const{ 33    return cost > b.cost; 34 } 35 }; 36 priority_queue<node>Q; 37 int f[N+5][25]; 38 39 void add(int u, int v, int c){ 40 edge[++top].to = v; 41 edge[top].next = path[u]; 42 edge[top].cost = c; 43 path[u] = top; 44 } 45 void dijkstra(){ 46 memset(f, 127/3, sizeof(f)); 47 f[s][0] = 0; 48 Q.push(node(0, s, 0)); 49 while (!Q.empty()){ 50    node tmp = Q.top(); Q.pop(); 51   for (int i = path[tmp.u]; i; i=edge[i].next){ 52    if (tmp.t < k && f[edge[i].to][tmp.t+1] > f[tmp.u][tmp.t]){ 53      f[edge[i].to][tmp.t+1] = f[tmp.u][tmp.t]; 54      Q.push(node(f[edge[i].to][tmp.t+1], edge[i].to, tmp.t+1)); 55    } 56    if (f[edge[i].to][tmp.t] > f[tmp.u][tmp.t]+edge[i].cost){ 57       f[edge[i].to][tmp.t] = f[tmp.u][tmp.t]+edge[i].cost; 58       Q.push(node(edge[i].to, edge[i].to, tmp.t)); 59    } 60    } 61 } 62 } 63 64 int main(){ 65 scanf("%d%d%d", &n, &m, &k); 66 scanf("%d%d", &s, &t);//[JLOI 2011]飛行路線 67 s = 1, t = n;//[USACO 09FEB]Revamping Trails 68 for (int i = 1; i <= m; i++){ 69    scanf("%d%d%d", &u, &v, &c); 70   add(u, v, c); 71    add(v, u, c); 72 } 73 dijkstra(); 74 printf("%d\n", f[t][k]); 75 return 0; 76 }

?

轉載于:https://www.cnblogs.com/NaVi-Awson/p/7473258.html

總結

以上是生活随笔為你收集整理的[JLOI 2011]飞行路线[USACO 09FEB]Revamping Trails的全部內容,希望文章能夠幫你解決所遇到的問題。

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