[JLOI 2011]飞行路线[USACO 09FEB]Revamping Trails
Description
Input
Output
Sample Input
0 4
0 1 5
1 2 5
2 3 5
3 4 5
2 3 3
0 2 100
Sample Output
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]$飞行路线,这两道题一毛一样。区别就是$USACO$的数据$k<=20$,并且$s=1$,$t=n$。
建立分层图。
$f[u][t]$表示在节点u时已经免费乘坐t次的最少花费。照样跑最短路。
枚举与$u$相连的所有节点$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$的优先队列还过不了,手打了个堆$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相关推荐
- 洛谷 P2939 [USACO09FEB]改造路Revamping Trails
洛谷 P2939 [USACO09FEB]改造路Revamping Trails Description 约翰一共有N)个牧场.由M条布满尘埃的小径连接.小径可 以双向通行.每天早上约翰从牧场1出发到 ...
- P4568 [JLOI2011]飞行路线 P2939 [USACO09FEB]改造路Revamping Trails
分层图最短路系列题目 分层图最短路的题目有一个非常容易看得出的把戏:让k条边免费. 对于能让\(k\)条边免费的数据,我们开\(k+1\)层图.每一层图内部正常连点,不同的是前一层的图的起点连一条权值 ...
- BZOJ1579 USACO 2009 Feb Gold 3.Revamping Trails Solution
标题效果:一个N积分m无向图边.它可以是路径k右边缘值变0,确定此时1-n最短路径长度. Sol:我以为我们考虑分层图,图复制k+1部分,每间0~k一层.代表在这个时候已经过去"自由边缘&q ...
- [USACO09FEB]改造路Revamping Trails 分层最短路 Dijkstra BZOJ 1579
题意翻译 约翰一共有N)个牧场.由M条布满尘埃的小径连接.小径可 以双向通行.每天早上约翰从牧场1出发到牧场N去给奶牛检查身体. 通过每条小径都需要消耗一定的时间.约翰打算升级其中K条小径,使之成为高 ...
- 洛谷P2939 [USACO09FEB]改造路Revamping Trails(最短路)
题目描述 Farmer John dutifully checks on the cows every day. He traverses some of the M (1 <= M <= ...
- [Usaco2009 Feb]Revamping Trails 道路升级
题目描述 每天,农夫John需要经过一些道路去检查牛棚N里面的牛. 农场上有M(1<=M<=50,000)条双向泥土道路,编号为1..M. 道路i连接牛棚P1_i和P2_i (1 < ...
- [USACO09FEB]Revamping Trails G
题意: 约翰一共有 N 个牧场.由 MM 条布满尘埃的小径连接.小径可以双向通行.每天早上约翰从牧场 1 出发到牧场 N 去给奶牛检查身体. 通过每条小径都需要消耗一定的时间.约翰打算升级其中 K 条 ...
- bzoj 1579: [Usaco2009 Feb]Revamping Trails 道路升级【分层图+spfa】
至死不用dijskstra系列2333,洛谷上T了一个点,开了O2才过 基本想法是建立分层图,就是建k+1层原图,然后相邻两层之间把原图的边在上一层的起点与下一层的终点连起来,边权为0,表示免了这条边 ...
- 【BZOJ】1579: [Usaco2009 Feb]Revamping Trails 道路升级
[算法]分层图最短路 [题解] 考虑k层一模一样的图,然后每个夹层都在每条边的位置新加从上一层跨越到下一层的边权为0的边,这样至多选择k条边置为0. 然后考虑方便的写法. SPFA 第一次SPFA计算 ...
最新文章
- 2021年江西省副高考试成绩查询,江西省教育考试院:2021年江西高考成绩查询入口、查分系统...
- Syntax error, annotations are only available if source level is 1.5 or greater.
- 一个按钮触发两个事件可以吗?
- Linux的Page Cache
- 线性代数行列式计算之迭代法
- 题目 2285: [蓝桥杯][2018年第九届真题]螺旋折线(数论+思维)
- 初探函数式编程和面对对象式编程
- ECCV 2020 大规模实例分割挑战赛(LVIS Challenge)冠军方案
- FTP 1 协议分析
- 转(A potentially dangerous Request.Form value was detected from the client)
- Linux基础命令---ziinfo
- 使得在虚拟机能复制粘贴 -- Linux安装增强
- 最受欢迎的9个前端UI框架
- 安卓手机获取root权限
- CentOS7.6 安装Oracle12C(上)
- delaunay三角剖分与delaunay四面体
- Browser-Solidity的本地安装及使用介绍
- 玉米田 炮兵阵地 状态压缩DP
- Proxmox VE(PVE)+ceph+物理网络规划-超融合生产环境安装部署案例
- 准备换工作 , 有备无患