给定一个n个点m条边的有向图,图中可能存在重边和自环, 边权可能为负数。

请你判断图中是否存在负权回路。

输入格式

第一行包含整数n和m。

接下来m行每行包含三个整数x,y,z,表示存在一条从点x到点y的有向边,边长为z。

输出格式

如果图中存在负权回路,则输出“Yes”,否则输出“No”。

数据范围

1≤n≤2000
1≤m≤10000
图中涉及边长绝对值均不超过10000。

输入样例:

  1. 3 3
  2. 1 2 -1
  3. 2 3 4
  4. 3 1 -4

输出样例:

  1. Yes
  2. 代码:
  1. //邻接表存储
  2. //n=1e5,不能用邻接表
  3.  
  4. import java.util.ArrayDeque;
  5. import java.util.Arrays;
  6. import java.util.Scanner;
  7.  
  8. public class Main{
  9. static final int N=100005, INF=0x3f3f3f3f;
  10. static int h[]=new int[N];
  11. static int e[]=new int[N];
  12. static int ne[]=new int[N];
  13. static int w[]=new int[N];
  14. static int dis[]=new int[N];
  15. static int cnt[]=new int[N];//
  16. static boolean vis[]=new boolean[N];
  17. static int n,m,idx;
  18. static void add(int a,int b,int c){
  19. e[idx]=b;
  20. w[idx]=c;
  21. ne[idx]=h[a];
  22. h[a]=idx++;
  23. }
  24. static boolean spfa(){
  25. ArrayDeque<Integer> q = new ArrayDeque<Integer>();
  26. Arrays.fill(dis, INF);
  27. dis[1]=0;
  28. for(int i=1;i<=n;i++){//不能只加入1了,因为每个点都要判断一下,负权回路并不是每个点都能进入的
  29. q.offer(i);
  30. vis[i]=true;
  31. }
  32. while(!q.isEmpty()){
  33. int t=q.poll();
  34. vis[t]=false;//不在队列中,置为false
  35. for(int i=h[t];i!=-1;i=ne[i]){
  36. int j=e[i];
  37. if(dis[j]>dis[t]+w[i]){
  38. dis[j]=dis[t]+w[i];
  39. cnt[j]=cnt[t]+1;
  40. if(cnt[j]>=n) return true;//如果存在负权回路,路径那么会一直执行更新,就是在这个负环中转圈;对图中的点,它最多经过n-1条边到达另一个点,所以大于等于n,肯定是存在负权回路
  41. if(!vis[j]){
  42. vis[j]=true;
  43. q.offer(j);
  44. }
  45. }
  46. }
  47. }
  48. return false;
  49. }
  50. public static void main(String[] args) {
  51. Scanner scan=new Scanner(System.in);
  52. n=scan.nextInt();
  53. m=scan.nextInt();
  54. Arrays.fill(h, -1);
  55. while(m-->0){
  56. int a=scan.nextInt();
  57. int b=scan.nextInt();
  58. int c=scan.nextInt();
  59. add(a,b,c);
  60. }
  61. if(spfa()) System.out.println("Yes");
  62. else System.out.println("No");
  63. }
  64. }

852. spfa判断负环的更多相关文章

  1. AcWing 852. spfa判断负环 边权可能为负数。

    #include <cstring> #include <iostream> #include <algorithm> #include <queue> ...

  2. POJ 3259 Wormholes【最短路/SPFA判断负环模板】

    农夫约翰在探索他的许多农场,发现了一些惊人的虫洞.虫洞是很奇特的,因为它是一个单向通道,可让你进入虫洞的前达到目的地!他的N(1≤N≤500)个农场被编号为1..N,之间有M(1≤M≤2500)条路径 ...

  3. spfa判断负环

    会了spfa这么长时间竟然不会判断负环,今天刚回.. [例题]poj3259 题目大意:当农场主 John 在开垦他的农场时,他发现了许多奇怪的昆虫洞.这些昆虫洞是单向的,并且可以把你从入口送到出口, ...

  4. spfa 判断负环 (转载)

    当然,对于Spfa判负环,实际上还有优化:就是把判断单个点的入队次数大于n改为:如果总的点入队次数大于所有点两倍 时有负环,或者单个点的入队次数大于sqrt(点数)有负环.这样时间复杂度就降了很多了. ...

  5. Wormholes---poj3259(最短路 spfa 判断负环 模板)

    题目链接:http://poj.org/problem?id=3259 题意是问是否能通过虫洞回到过去: 虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts. 我们把虫洞看成是一条负权路,问 ...

  6. POJ 3259 Wormholes ( SPFA判断负环 && 思维 )

    题意 : 给出 N 个点,以及 M 条双向路,每一条路的权值代表你在这条路上到达终点需要那么时间,接下来给出 W 个虫洞,虫洞给出的形式为 A B C 代表能将你从 A 送到 B 点,并且回到 C 个 ...

  7. Extended Traffic LightOJ - 1074 spfa判断负环

    //判断负环 在负环内的城市输出? #include <iostream> #include <queue> #include <cstdio> #include ...

  8. Wormholes POJ - 3259 spfa判断负环

    //判断负环 dist初始化为正无穷 //正环 负无穷 #include<iostream> #include<cstring> #include<queue> # ...

  9. UVA 558 SPFA 判断负环

    这个承认自己没看懂题目,一开始以为题意是形成环路之后走一圈不会产生负值就输出,原来就是判断负环,用SPFA很好用,运用队列,在判断负环的时候,用一个数组专门保存某个点的访问次数,超过了N次即可断定有负 ...

随机推荐

  1. Unity5.5.6 升级到 2018.4.1 打包出现的问题 : Gradle version 2.10 is required. Current version is 5.1.1

    起因:最近要在googleplay上架新游戏,而谷歌要求新上架的应用要支持64位,鉴于老版本的unity不支持打包64位apk,所以决定升级unity版本到2018.4.1, 但打包过程中出现了几个问 ...

  2. 【问题】多重继承时,super函数只初始化继承的第一个类,不初始化第二个类。

    class A(object): def __init__(self): print("init class A") class B(object): def __init__(s ...

  3. oracle数据库重要的查询语句

    查看所有数据文件(dbf文件)的存放位置 SQL> select name from v$datafile; 标红色的为默认表空间文件 SQL> select name from v$da ...

  4. webpack--介绍、安装及入门

    最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载.下面的网页代码,相信很多人都见过. <scr ...

  5. 细读jsr中的yield语义,或者不是我们想象中的那样

    这只是我的个人观点,如有错误,希望你可以指出. 首先英文原版 中文译版 我觉得“不需要”还会让人产生误解,应该译为不一定要. 很多时候会被断章取义地理解,我们一定要有“不一定”,“可能”的意识,下面给 ...

  6. JMeter函数助手中Random函数详解

    1.__Random函数的生成 The minimum value allowed for a range of values:一个范围内允许的最小值 The maximum value allowe ...

  7. 【读书笔记】https://source.android.google.cn/devices/bootloader

    https://source.android.google.cn/devices/bootloader 本文主要记录aosp官网关于bootloader的相关资料 Bootloader A bootl ...

  8. 基于JavaSwing开发银行信用卡管理系统

    开发环境: Windows操作系统开发工具: MyEclipse10/Eclipse+Jdk+Mysql数据库 运行效果图 源码及原文链接:https://javadao.xyz/forum.php? ...

  9. Vue中import from的来源--省略后缀与加载文件夹

    Vue使用import ... from ...来导入组件,库,变量等.而from后的来源可以是js,vue,json.这个是在webpack.base.conf.js中设置的: module.exp ...

  10. day 17 初始递归

    递归函数 了解什么是递归 : 在函数中调用自身函数 最大递归深度默认是997/998 —— 是python从内存角度出发做的限制 能看懂递归 能知道递归的应用场景 初识递归 —— 算法 —— 二分查找 ...