码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • UVA - 10765 Doves and bombs


    CUC DFS及其应用 - Virtual Judge

    题目大意:有一个n个点的图,求每个点如果被删除后,图中剩余连通块的数量

    1<=n<=1e4

    思路:也就是求每一个割点出现在几个双联通分量(没有割点的图)中,找双连通分量也是用tarjan,dfn[u]表示u是第几个遍历到的点,low[u]表示从u出发在不经过父子边的情况下能到达的最早的祖先的dfn值,而如果一个点是割点,那么在不经过该点的情况下无法到达该点的祖先也就是low[v]>=dfn[u],注意特判起始点的情况,它可能是假割点

    1. //#include<__msvc_all_public_headers.hpp>
    2. #include
    3. using namespace std;
    4. const int N = 1e4 + 5;
    5. int head[N], head2[N];
    6. struct Edge
    7. {
    8. int v, next;
    9. }e[N*10];
    10. int cnt = 0;
    11. int n,m;
    12. int dfn[N];
    13. void addedge(int u, int v)
    14. {
    15. e[++cnt].v = v;
    16. e[cnt].next = head[u];
    17. head[u] = cnt;
    18. }
    19. struct Node
    20. {
    21. int id, cn;
    22. }node[N];
    23. int tot = 0;
    24. void init()
    25. {
    26. tot = 0;
    27. cnt = 0;
    28. for (int i = 0; i <= n; i++)
    29. {
    30. node[i].id = i;
    31. node[i].cn = 1;//答案至少是1
    32. head[i] = -1;
    33. dfn[i] = 0;
    34. }
    35. }
    36. int tarjan(int u,int fa)
    37. {
    38. int lowu = dfn[u] = ++tot;
    39. int child = 0;
    40. for (int i = head[u]; ~i; i = e[i].next)
    41. {
    42. int v = e[i].v;
    43. if (!dfn[v])
    44. {
    45. child++;
    46. int lowv = tarjan(v, u);
    47. lowu = min(lowu, lowv);
    48. if (lowv >= dfn[u])
    49. {//该点是割点
    50. node[u].cn++;
    51. }
    52. }
    53. else if (dfn[v] < dfn[u] && v != fa)
    54. {
    55. lowu = min(lowu, dfn[v]);
    56. }
    57. }
    58. if (fa < 0 && child == 1)
    59. {//假割点
    60. node[u].cn = 1;
    61. }
    62. return lowu;
    63. }
    64. bool cmp(Node a, Node b)
    65. {
    66. return a.cn == b.cn ? a.idb.cn;
    67. }
    68. void solve()
    69. {
    70. init();
    71. int u, v;
    72. while(cin>>u>>v)
    73. {
    74. if (u == -1 && v == -1)
    75. {
    76. break;
    77. }
    78. addedge(u, v);
    79. addedge(v, u);
    80. }
    81. tarjan(0, -1);
    82. sort(node, node + n, cmp);
    83. for (int i = 0; i < m; i++)
    84. {
    85. cout << node[i].id << " " << node[i].cn << endl;
    86. }
    87. cout << endl;
    88. }
    89. int main()
    90. {
    91. ios::sync_with_stdio(false);
    92. cin.tie(0);
    93. int t;
    94. //cin >> t;
    95. while (cin>>n>>m)
    96. {
    97. if (!n&&!m)
    98. {
    99. break;
    100. }
    101. solve();
    102. }
    103. return 0;
    104. }

  • 相关阅读:
    electron + vtkjs加载模型异常,界面显示类似于图片加载失败的图标
    JavaScript函数
    深入探索C与C++的混合编程
    力扣(LeetCode)320. 列举单词的全部缩写(2022.11.17)
    自动化测试:yaml结合ddt实现数据驱动!
    如何通俗理解超级浏览器?可以用于哪些场景?有哪些品牌?
    【Java基础面试三十五】、谈谈你对面向接口编程的理解
    信号特点,异步/同步概念,查看信号(kill -l,man 7 signa),实时/分时os概念
    linux 应急响应工具整理列表
    贯穿设计模式第一话--单一职责原则
  • 原文地址:https://blog.csdn.net/ashbringer233/article/details/133623056
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号