Wormholes (spfa)
一种路是双向的,路的长度是正值;另一种路是单向的,路的长度是负值; 如果有负环输出YES;否则输出NO;不同的路可能有相同的起点和终点:必须用邻接表
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 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
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 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.
Sponsor
1 #include<iostream>
2 #include<cstdio>
3 #include<cstdlib>
4 #include<cstring>
5 #include<algorithm>
6 #include<cmath>
7 #include<queue>
8 #include<vector>
9 #include<map>
10 #include<string>
11 #define LL long long
12 #define eps 1e-8
13 using namespace std;
14 const int inf = 0x3f3f3f3f;
15 int n,m,w,a,b,c,t,tot,ans;
16 struct node{
17 int l,r,num,nex;
18 }e[10010];
19 int head[550],vis[550],dis[550],sum[550];
20
21 void init()
22 {
23
24 memset(head,-1,sizeof(head));
25 tot=0;
26 ans=0;
27 }
28
29 void add(int l,int r,int num)
30 {
31 e[tot].l=l,e[tot].r=r,e[tot].num=num;
32 e[tot].nex=head[l];
33 head[l]=tot++;
34 }
35
36 int spfa(int x)
37 {
38 queue<int >q;
39 while(!q.empty())
40 q.pop();
41 memset(dis,inf,sizeof(dis));
42 memset(vis,0,sizeof(vis));
43 memset(sum,0,sizeof(sum));
44 q.push(x);
45 vis[x]=1;
46 dis[x]=0;
47 sum[x]=1;
48 while(!q.empty())
49 {
50 int now=q.front(); q.pop();
51 vis[now]=0;
52 for(int i=head[now];i!=-1;i=e[i].nex)
53 {
54 int to=e[i].r;
55 if(dis[to]>dis[now]+e[i].num)
56 {
57 dis[to]=dis[now]+e[i].num;
58 if(!vis[to])
59 {
60 sum[to]++;
61 if(sum[to]>n) return 1;
62 q.push(to);
63 vis[to]=1;
64 }
65 }
66 }
67 }
68 return 0;
69 }
70 int main()
71 {
72 scanf("%d",&t);
73 while(t--)
74 {
75 scanf("%d%d%d",&n,&m,&w);
76 init();
77 while(m--)
78 {
79 scanf("%d%d%d",&a,&b,&c);
80 add(a,b,c);
81 add(b,a,c);
82 }
83 while(w--)
84 {
85 scanf("%d%d%d",&a,&b,&c);
86 add(a,b,-c);
87 }
88 for(int i=1;i<=n;i++)
89 {
90 if(spfa(i)){
91 ans=1;
92 break;//否则超时
93 }
94 }
95 if(ans) printf("YES\n");
96 else printf("NO\n");
97 }
98 }
Wormholes (spfa)的更多相关文章
- ACM:  POJ 3259 Wormholes - SPFA负环判定
		POJ 3259 Wormholes Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu ... 
- poj 3259 Wormholes spfa算法
		点击打开链接 Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 25582 Accepted: 9186 ... 
- Wormholes(SPFA+Bellman)
		Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 36860 Accepted: 13505 Descr ... 
- POJ 1151 Wormholes spfa+反向建边+负环判断+链式前向星
		Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 49962 Accepted: 18421 Descr ... 
- POJ3259 :Wormholes(SPFA判负环)
		POJ3259 :Wormholes 时间限制:2000MS 内存限制:65536KByte 64位IO格式:%I64d & %I64u 描述 While exploring his many ... 
- POJ3259 Wormholes(SPFA判断负环)
		Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ... 
- POJ3259 Wormholes —— spfa求负环
		题目链接:http://poj.org/problem?id=3259 Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submis ... 
- uva558  Wormholes SPFA 求是否存在负环
		J - Wormholes Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit Stat ... 
- POJ 3259 Wormholes(SPFA判负环)
		题目链接:http://poj.org/problem?id=3259 题目大意是给你n个点,m条双向边,w条负权单向边.问你是否有负环(虫洞). 这个就是spfa判负环的模版题,中间的cnt数组就是 ... 
随机推荐
- 隐马尔科夫模型(HMM)原理详解
			隐马尔可夫模型(Hidden Markov Model,HMM)是可用于标注问题的统计学习模型,描述由隐藏的马尔可夫链随机生成观测序列的过程,属于生成模型.HMM在语音识别.自然语言处理.生物信息.模 ... 
- session、cookie、token的区别
			从安全性优先级来说: 1.优先级 Cookie<session<token 2. 安全性 Cookie: ①cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺 ... 
- 【Docker】Docker概述、理解docker的集装箱、标准化、隔离的思想、 docker出现解决了什么问题
			整理一下 慕课网 第一个docker化的java应用 Docker环境下的前后端分离项目部署与运维 课程时所做的笔记 Docker概述 docker - https://www.docker.com/ ... 
- 【Web】实现动态文章列表
			简单记录 -慕课网- 步骤二:动态文章列表效果 实现这个 一个网页中常见的文章列表效果. 怎么实现文章列表案例 分解一波,CSS来改变样式 标题标签 HTML的无序列表 去掉项目符号 符号所占空间 列 ... 
- 【Oracle】表空间配额问题
			由于需求,需要新建用户,但是新建的用户,会有相关的配额跟着,莫名其妙的问题让人很头疼 下面介绍下如何修改成不限制配额 select * from user_ts_quotas ; alter user ... 
- 【Oracle】等待事件之 V$SESSION_WAIT
			(1)-V$SESSION_WAIT 这是一个寻找性能瓶颈的关键视图.它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做,则显示它最后的等待事件).当系统存 ... 
- 【RAC】运行root.sh的时候报错root.sh Oracle CRS stack is already configured and will be running under init(1M)
			环境:oracle10g 系统:CentOS6.4 开始的时候,在节点1上运行root.sh发现出现90s 的时候hang住了,结束掉,结局完事后,再次运行root.sh报错 WARNING: dir ... 
- Trollcave-suid提权
			一 扫描端口 扫描开放端口:nmap -sV -sC -p- 192.168.0.149 -oA trollcave-allports 扫描敏感目录:gobuster dir -u http://19 ... 
- kubernetes 核心技术-Controller 控制器
			一.什么是Controller? Controller是在集群上管理和运行容器的对象,Controller是实际存在的,Pod是抽象的,主要创建管理pod 二.Pod和Controller的关系 Po ... 
- 前端面试之CSS权重问题!
			前端面试之CSS权重问题! 下面的权重按照从小到大来排列! 1.通用选择器(*) 2.元素(类型)选择器 权重1 3.类选择器 权重10 4.属性选择器 5.伪类 6.ID 选择器 权重100 7.内 ... 
