码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 负环判断——虫洞(裸题)


    poj传送门:3259 -- Wormholes

    思路:鉴定为——负环裸题。

    注意:多测试样例,且题目没有说一个农场之内的所有田地都能互相到达,所以要把所有点入队。

    至于为什么距离一开始可以初始化为0,因为图里面存在负环和负权边的情况下不管初始化为什么,最后负环上的都会变成负无穷。

    1. #include
    2. #include
    3. #include
    4. #include
    5. using namespace std;
    6. typedef long long ll;
    7. const int N=1e3,M=6e3;
    8. int e[M],ne[M],h[N],w[M],idx;
    9. int dist[N];
    10. int q[N];
    11. bool st[N];
    12. int cnt[N];
    13. int n,m,w1;
    14. void add(int a,int b,int c)
    15. {
    16. e[idx]=b,ne[idx]=h[a],w[idx]=c,h[a]=idx++;
    17. }
    18. bool spfa()
    19. {
    20. int hh=0,tt=0;
    21. memset(dist,0,sizeof dist);
    22. memset(st,0,sizeof st);
    23. memset(cnt,0,sizeof cnt);
    24. for(int i=1;i<=n;i++)
    25. {
    26. q[tt++]=i;
    27. st[i]=true;
    28. }
    29. while(hh!=tt)
    30. {
    31. int t=q[hh++];
    32. if(hh==N)hh=0;
    33. st[t]=false;
    34. for(int i=h[t];~i;i=ne[i])
    35. {
    36. int j=e[i];
    37. if(dist[j]>dist[t]+w[i])
    38. {
    39. dist[j]=dist[t]+w[i];
    40. cnt[j]=cnt[t]+1;
    41. if(cnt[j]>=n)return true;
    42. if(!st[j])
    43. {
    44. q[tt++]=j;
    45. if(tt==N) tt=0;
    46. st[j]=true;
    47. }
    48. }
    49. }
    50. }
    51. return false;
    52. }
    53. int main()
    54. {
    55. int t;
    56. scanf("%d",&t);
    57. while(t--)
    58. {
    59. scanf("%d%d%d",&n,&m,&w1);
    60. memset(h,-1,sizeof h);
    61. idx=0;
    62. for(int i=1;i<=m;i++)
    63. {
    64. int a,b,c;
    65. scanf("%d%d%d",&a,&b,&c);
    66. add(a,b,c);
    67. add(b,a,c);
    68. }
    69. for(int i=1;i<=w1;i++)
    70. {
    71. int a,b,c;
    72. scanf("%d%d%d",&a,&b,&c);
    73. add(a,b,-c);
    74. }
    75. if(spfa())puts("YES");
    76. else puts("NO");
    77. }
    78. return 0;
    79. }
    80. //I LOVE YOU

  • 相关阅读:
    Java版分布式微服务云开发架构 Spring Cloud+Spring Boot+Mybatis 电子招标采购系统功能清单
    ArcGIS中ArcMap栅格图层0值设置为NoData值的简便方法
    过滤器,simple_tag,inclusion_tag,模板继承
    ESP32-C3入门教程 基础篇⑥——SPI通信点亮LCD显示屏
    C#多线程学习(二) 如何操纵一个线程
    有趣的设计模式——适配器模式让两脚插头也能使用三孔插板
    springboot集成redis
    最新720全景云系统/可生成小程序+带PC端+安装教程/价值800元的720云全景系统源码
    java计算机毕业设计商院足球赛事管理源程序+mysql+系统+lw文档+远程调试
    Python中的魔法函数(__init__()和__ str__())
  • 原文地址:https://blog.csdn.net/m0_62327332/article/details/127069298
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号