手铐

思路:

缩环+树形dp

代码:

  1. #pragma GCC optimize(2)
  2. #pragma GCC optimize(3)
  3. #pragma GCC optimize(4)
  4. #include<bits/stdc++.h>
  5. using namespace std;
  6. #define y1 y11
  7. #define fi first
  8. #define se second
  9. #define pi acos(-1.0)
  10. #define LL long long
  11. //#define mp make_pair
  12. #define pb emplace_back
  13. #define ls rt<<1, l, m
  14. #define rs rt<<1|1, m+1, r
  15. #define ULL unsigned LL
  16. #define pll pair<LL, LL>
  17. #define pli pair<LL, int>
  18. #define pii pair<int, int>
  19. #define piii pair<pii, int>
  20. #define pdd pair<double, double>
  21. #define mem(a, b) memset(a, b, sizeof(a))
  22. #define debug(x) cerr << #x << " = " << x << "\n";
  23. #define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
  24. //head
  25. const int N = 1e6 + 5;
  26. const int MOD = 19260817;
  27. vector<int> g[N], G[N];
  28. int bcc[N], sz[N], Cnt[N];
  29. int dp[N];
  30. bool vis[N];
  31. int low[N], dfn[N], stk[N], tot = 0, top = 0, cnt = 0;
  32. inline void tarjan(int u, int fa) {
  33. low[u] = dfn[u] = ++tot;
  34. stk[++top] = u;
  35. vis[u] = true;
  36. for (int v : g[u]) {
  37. if(v == fa) continue;
  38. if(!dfn[v]) {
  39. tarjan(v, u);
  40. low[u] = min(low[u], low[v]);
  41. }
  42. else if(vis[v]) low[u] = min(low[u], dfn[v]);
  43. }
  44. if(low[u] == dfn[u]) {
  45. ++cnt;
  46. while(stk[top] != u) vis[stk[top]] = false, bcc[stk[top--]] = cnt;
  47. vis[stk[top]] = false, bcc[stk[top--]] = cnt;
  48. }
  49. }
  50. int n, m, u, v;
  51. int ans;
  52. inline void dfs(int u, int o) {
  53. if(Cnt[u] != 1) dp[u] = 1;
  54. else dp[u] = 0;
  55. for (int v : G[u]) {
  56. if(v == o) continue;
  57. dfs(v, u);
  58. ans = (ans + dp[u]*1LL*dp[v]%MOD) % MOD;
  59. if(Cnt[u] != 1) dp[u] = (dp[u] + dp[v]*2) % MOD;
  60. else dp[u] = (dp[u] + dp[v]) % MOD;
  61. }
  62. }
  63. int main() {
  64. scanf("%d %d", &n, &m);
  65. for (int i = 1; i <= m; ++i) scanf("%d %d", &u, &v), g[u].pb(v), g[v].pb(u);
  66. tarjan(1, 0);
  67. for (int i = 1; i <= n; ++i) {
  68. for (int v : g[i]) {
  69. if(bcc[i] == bcc[v]) continue;
  70. G[bcc[i]].pb(bcc[v]);
  71. }
  72. Cnt[bcc[i]]++;
  73. }
  74. dfs(1, 0);
  75. ans = (ans + MOD) % MOD;
  76. printf("%d\n", ans);
  77. return 0;
  78. }

牛客练习赛6 C 手铐的更多相关文章

  1. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

  2. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  3. 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A

    牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...

  4. 最小生成树--牛客练习赛43-C

    牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 ​ 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...

  5. 牛客练习赛28-B(线段树,区间更新)

    牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ ​ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, ​ 1 l r 询问区间[l,r]内的元素和 ​ 2 l r 询问区间[l,r]内的 ...

  6. 牛客练习赛26:D-xor序列(线性基)

    链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...

  7. [堆+贪心]牛客练习赛40-B

    传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费  x_i 的时间,同时完成第 i 个任务的时间不 ...

  8. 牛客练习赛 29 E 位运算?位运算!(线段树)

    题目链接  牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...

  9. 牛客练习赛22C Bitset

    牛客练习赛22C 一共有 n个数,第 i 个数是 xi  xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...

随机推荐

  1. Python机器学习基础教程-第2章-监督学习之决策树

    前言 本系列教程基本就是摘抄<Python机器学习基础教程>中的例子内容. 为了便于跟踪和学习,本系列教程在Github上提供了jupyter notebook 版本: Github仓库: ...

  2. 在Jetty中部署Jenkins遇到的问题

    1. Jetty 9.0.3 启动时的错误: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 [root@kvm-guest jetty-9.0.3]# java -jar star ...

  3. Python数据挖掘之随机森林

    主要是使用随机森林将four列缺失的数据补齐. # fit到RandomForestRegressor之中,n_estimators代表随机森林中的决策树数量 #n_jobs这个参数告诉引擎有多少处理 ...

  4. JDBC缓冲池配置druid.properties

    driverClassName=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mytest?characterEncoding=UTF-8 ...

  5. golang之格式化fmt.Printf

    当使用fmt包打印一个数值时,我们可以用%d.%o或%x参数控制输出的进制格式,就像下面的例子: o := 0666 fmt.Printf("%d %[1]o %#[1]o\n", ...

  6. SQL——UPDATE(改)

    一.UPDATE语句基本用法 UPADTE语句用于修改表中已存在的记录. UPDATE语句语法: UPDATE 表名 SET 列名1 = 值1,列名2 = 值2... WHERE 条件语句; 演示st ...

  7. 在vue中使用ElementUI

    完整引用ElementUI: 安装:在需要使用到的vue项目目录下,使用npm下载安装: npm/cnpm i element-ui -S/--save <!-- 引入样式 --> < ...

  8. ALV报表——抓取工单长文

    ABAP抓取工单长文 运行效果: 代码: *&---------------------------------------------------------------------* *& ...

  9. spring整合MQ

    ---恢复内容开始--- 一. 导入依赖 <dependencies> <!-- ActiveMQ客户端完整jar包依赖 --> <dependency> < ...

  10. MySQL 索引机制

    MySQL 原理篇 MySQL 索引机制 MySQL 体系结构及存储引擎 MySQL 语句执行过程详解 MySQL 执行计划详解 MySQL InnoDB 缓冲池 MySQL InnoDB 事务 My ...