Wormholes
2016-03-01 15:07
246 查看
负权回路判断,有重边有自环,万能的spfa解决
http://poj.org/problem?id=3259
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 Tseconds.
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.
http://poj.org/problem?id=3259
Wormholes
Time Limit: 2000MS | Memory Limit: 65536K | |
Total Submissions: 39617 | Accepted: 14559 |
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 Tseconds.
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.
#include <cstdio> #include <cstring> #include <vector> #include <algorithm> #include <queue> #define Min(a,b) a>b?b:a; #define Max(a,b) a>b?a:b; using namespace std; const int SIZE=5e2+10; const int maxn=1<<30; struct node{ int v;int w; node(){} node(int vv,int ww):v(vv),w(ww){} }; vector<vector<node> >G; int cost[SIZE][SIZE]; int dis[SIZE]; bool spfa(int s,int n){ int uptimes[SIZE]; memset(uptimes,0,sizeof(uptimes)); for(int i=1;i<=n;i++) dis[i]=maxn; dis[s]=0; queue<int>q; q.push(s); while(!q.empty()){ int u=q.front(); q.pop(); for(int i=0;i<G[u].size();i++){ int v=G[u][i].v; int w=G[u][i].w; if(w!=cost[u][v])continue; if(dis[v]<=dis[u]+w)continue; dis[v]=dis[u]+w; q.push(v); uptimes[v]++; if(uptimes[v]>=n)return true; } } return false; } int main() { int T; scanf("%d",&T); while(T--){ memset(cost,0,sizeof(cost)); int n,m,x,u,v,w; scanf("%d%d%d",&n,&m,&x); G.clear(); G.resize(n+10); for(int i=0;i<m;i++){ scanf("%d%d%d",&u,&v,&w); if(u==v)continue; G[u].push_back(node(v,w)); G[v].push_back(node(u,w)); if(cost[u][v]){ cost[u][v]=cost[v][u]=Min(cost[v][u],w); } else cost[u][v]=cost[v][u]=w; } for(int i=0;i<x;i++){ scanf("%d%d%d",&u,&v,&w); G[u].push_back(node(v,-w)); cost[u][v]=Min(cost[u][v],-w); } if(spfa(1,n))printf("YES\n"); else printf("NO\n"); } return 0; }
相关文章推荐
- Ground truth
- AngularJS 数组
- 单链表
- 设计模式 ( 一 )
- C++自制Redis 数据库 (十五)【重构】数据库学习(一)
- HDU 2553 N皇后问题
- AngularJS 对象
- spring整合quartz实现定时任务
- 跨域
- scala符号
- 在vs2010或者vs2008中配置PC-lint9.0版http://blog.csdn.net/whatday/article/details/7890092
- 安卓7.0首批截图公布:惊现汉堡菜单
- int 0x13中断的參数传递
- 堆和栈的区别
- AngularJS 对象
- struts2的工作原理
- RegionServer Splitting Implementation:regionServer 分裂过程分析
- 深入分析js中的constructor 和prototype
- Android开发之创建桌面快捷方式
- scala def隐式函数