POJ 3259 Wormholes
2016-04-17 09:10
281 查看
Wormholes
Description
While exploring his many farms, Farmer John has discovered a number of amazing wormholes. A wormhole is very peculiar because it is a one-way path that delivers you to its destination at a time that is BEFORE you entered the wormhole! Each of FJ's farms
comprises N (1 ≤ N ≤ 500) fields conveniently numbered 1..N,
M (1 ≤ M ≤ 2500) paths, and W (1 ≤ W ≤ 200) wormholes.
As FJ is an avid time-traveling fan, he wants to do the following: start at some field, travel through some paths and wormholes, and return to the starting field a time before his initial departure. Perhaps he will be able to meet himself :) .
To help FJ find out whether this is possible or not, he will supply you with complete maps to
F (1 ≤ F ≤ 5) of his farms. No paths will take longer than 10,000 seconds to travel and no wormhole can bring FJ back in time by more than 10,000 seconds.
Input
Line 1: A single integer, F. F farm descriptions follow.
Line 1 of each farm: Three space-separated integers respectively: N,
M, and W
Lines 2..M+1 of each farm: Three space-separated numbers (S,
E, T) that describe, respectively: a bidirectional path between
S and E that requires T seconds to traverse. Two fields might be connected by more than one path.
Lines M+2..M+W+1 of each farm: Three space-separated numbers (S,
E, T) that describe, respectively: A one way path from S to
E that also moves the traveler back T seconds.
Output
Lines 1..F: For each farm, output "YES" if FJ can achieve his goal, otherwise output "NO" (do not include the quotes).
Sample Input
Sample Output
Hint
For farm 1, FJ cannot travel back in time.
For farm 2, FJ could travel back in time by the cycle 1->2->3->1, arriving back at his starting location 1 second before he leaves. He could start from anywhere on the cycle to accomplish this.
带负圈的最短路径问题,用Bellman_Ford算法或者SPFA算法都能过
Time Limit: 2000MS | Memory Limit: 65536K | |
Total Submissions: 40699 | Accepted: 14914 |
While exploring his many farms, Farmer John has discovered a number of amazing wormholes. A wormhole is very peculiar because it is a one-way path that delivers you to its destination at a time that is BEFORE you entered the wormhole! Each of FJ's farms
comprises N (1 ≤ N ≤ 500) fields conveniently numbered 1..N,
M (1 ≤ M ≤ 2500) paths, and W (1 ≤ W ≤ 200) wormholes.
As FJ is an avid time-traveling fan, he wants to do the following: start at some field, travel through some paths and wormholes, and return to the starting field a time before his initial departure. Perhaps he will be able to meet himself :) .
To help FJ find out whether this is possible or not, he will supply you with complete maps to
F (1 ≤ F ≤ 5) of his farms. No paths will take longer than 10,000 seconds to travel and no wormhole can bring FJ back in time by more than 10,000 seconds.
Input
Line 1: A single integer, F. F farm descriptions follow.
Line 1 of each farm: Three space-separated integers respectively: N,
M, and W
Lines 2..M+1 of each farm: Three space-separated numbers (S,
E, T) that describe, respectively: a bidirectional path between
S and E that requires T seconds to traverse. Two fields might be connected by more than one path.
Lines M+2..M+W+1 of each farm: Three space-separated numbers (S,
E, T) that describe, respectively: A one way path from S to
E that also moves the traveler back T seconds.
Output
Lines 1..F: For each farm, output "YES" if FJ can achieve his goal, otherwise output "NO" (do not include the quotes).
Sample Input
2 3 3 1 1 2 2 1 3 4 2 3 1 3 1 3 3 2 1 1 2 3 2 3 4 3 1 8
Sample Output
NO YES
Hint
For farm 1, FJ cannot travel back in time.
For farm 2, FJ could travel back in time by the cycle 1->2->3->1, arriving back at his starting location 1 second before he leaves. He could start from anywhere on the cycle to accomplish this.
带负圈的最短路径问题,用Bellman_Ford算法或者SPFA算法都能过
#include <stdio.h> #include <string.h> int N, M, W; struct node { int u; int v; int w; } map[5500]; int dist[505]; bool Bellman_Ford() { int i, j; for(i = 1; i < N; i++) for(j = 1; j <= 2*M+W; j++) if(dist[map[j].u] + map[j].w < dist[map[j].v]) dist[map[j].v] = dist[map[j].u] + map[j].w; for(i = 1; i <= 2*M+W; i++) if(dist[map[i].u] + map[i].w < dist[map[i].v]) return true; return false; } int main() { int F, i, j, S, E, T; scanf("%d", &F); while(F--) { memset(dist, 0x3f, sizeof(dist)); scanf("%d%d%d", &N, &M, &W); for(i = 1; i <= M; i++) { scanf("%d%d%d", &S, &E, &T); map[2*i-1].u = S; map[2*i-1].v = E; map[2*i-1].w = T; map[2*i].u = E; map[2*i].v = S; map[2*i].w = T; } for(i = 1; i <= W; i++) { scanf("%d%d%d", &S, &E, &T); map[2*M+i].u = S; map[2*M+i].v = E; map[2*M+i].w = -T; } dist[1] = 0; if(Bellman_Ford()) printf("YES\n"); else printf("NO\n"); } return 0; }
相关文章推荐
- Tech Blog
- 基于zookeeper应用——简单统一命名服务实现
- PHP垃圾回收机制
- 程序员必须要掌握的排序算法以及查找方法
- iOS之const,static,extern简介
- 项目内部IT/电商/信息化类简报,分享电子版
- MySql 数据库常用的sql语句
- Web安全测试之XSS
- 管道 && 消息队列 && 共享内存
- 对话吴恩达(Andrew Ng):超级大咖深度解析人工智能 以及如何成为已经数据挖掘工程师
- "Couldn't communicate with a helper application" in Xcode 7
- 第七周学习进度
- Eclipse中改变默认的workspace的方法及说明详解
- BZOJ 4206 转换之后求LIS
- 限制UITextField的最大输入字符数
- 常用链接
- 理解javascript对象继承
- JDK之jstat的用法
- Juel 表达式使用
- Juel 表达式使用