F. Independent Set

题意

一颗 n 个节点的树,求出每个\(edge-induced~subgraph\)的独立集个数之和。

\(edge-induced~subgraph\)含义是对于边集\(E,(E'\subset E)\),\(E\) 中的所有点都在该子图中。

注意到题目要求的结果中,E' 不能为空

分析

首先选出子图,问题转换成在森林中选出一些点,他们互相没有边,求这样的点集的个数。对于一棵树上的问题,可以用树形DP求出

设 \(d[x][0]\) 表示不选 x 的方案数,\(d[x][1]\) 表示选 x 的方案数

\(d[x][0] = \prod (d[y][1] + d[y][0])\\d[x][1] = \prod d[y][0]\)

但是此题中 x 和 y 不一定在一棵树中,所以还要考虑 \(x\rightarrow y\) 这条边的状态。

  1. 该边在subgraph 中,则 x 的状态与 y 的状态有关联

  2. 该边不在subgraph中,则 x 的状态与 y 的状态没有关联

考虑这两种状态,有转移方程:

\(d[x][0] = \prod 2 * (d[y][1] + d[y][0])\)

\(d[x][1] = \prod (d[y][0] + d[y][1] + d[y][0])\)

到这里似乎问题已经得到解决,但是要注意到,“单点” 这种情况是不允许出现的,因为题目中的子图是由边集构造的,所以要考虑去除掉这种情况。

设 \(f[x]\) 表示 x 与所有的子节点 y 所连的边都不在子图中的方案数

在用 \(f[y]\) 去更新 x 时,如果 \(x\rightarrow y\) 这条边不被选中,则 y 被选中的状态 \(d[y][1]\) 应该减去 \(f[y]\), 这代表着 y 不能作为单点被选中,所以有如下转移:

\[\begin{cases}
d[x][0]= \prod (d[y][1]+d[y][0]) + (d[y][1]-f[y]+d[y][0]) \\
d[x][1] = \prod (d[y][0]) + (d[y][1] - f[y] + d[y][0])\\
f[x] = \prod (d[y][1]-f[y]+d[y][0])
\end{cases}
\]

最终答案应该是 \(d[1][0]+d[1][1]-f[1]-1\), 最后减去 1 是减去了空子图的情况

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int inf = 0x3f3f3f3f;
#define dbg(x...) do { cout << "\033[32;1m" << #x <<" -> "; err(x); } while (0)
void err() { cout << "\033[39;0m" << endl; }
template<class T, class... Ts> void err(const T& arg,const Ts&... args) { cout << arg << " "; err(args...); }
const int N = 300000 + 5;
const int mod = 998244353;
int head[N], ver[N<<1], nxt[N<<1], tot;
int n;
ll d[N][2], f[N];
void add(int x, int y){
ver[++tot] = y, nxt[tot] = head[x], head[x] = tot;
}
void dfs(int x, int fa){
d[x][0] = d[x][1] = f[x] = 1;
for(int i=head[x];i;i=nxt[i]){
int y = ver[i];
if(y == fa) continue;
dfs(y, x);
d[x][0] = d[x][0] * ((2 * d[y][0] + 2 * d[y][1] - f[y])%mod) % mod;
d[x][1] = d[x][1] * ((2 * d[y][0] + d[y][1] - f[y]) % mod) % mod;
f[x] = f[x] * ((d[y][0] + d[y][1] - f[y]) % mod) % mod;
}
dbg(x, d[x][0], d[x][1], f[x]);
}
int main(){
scanf("%d", &n);
for(int i=2;i<=n;i++){
int x, y;
scanf("%d%d", &x, &y);
add(x, y);
add(y, x);
}
dfs(1, 0);
cout << (d[1][0] + d[1][1] - f[1] - 1 + 2 * mod) % mod;
return 0;
}

这题代码很容易写,关键是要把DP转移搞清楚,CF的题目解释很清晰,而且样例还给解释,要是放在比赛上能遇到这样的Hint就谢天谢地了

CF-1332 F. Independent Set的更多相关文章

  1. CF R 630 div2 1332 F Independent Set

    LINK:Independent Set 题目定义了 独立集和边诱导子图.然而和题目没有多少关系. 给出一棵树 求\(\sum_{E'\neq \varnothing,E'\subset E}w(G( ...

  2. CF 633 F. The Chocolate Spree 树形dp

    题目链接 CF 633 F. The Chocolate Spree 题解 维护子数答案 子数直径 子数最远点 单子数最长直径 (最长的 最远点+一条链) 讨论转移 代码 #include<ve ...

  3. CF #271 F Ant colony 树

    题目链接:http://codeforces.com/contest/474/problem/F 一个数组,每一次询问一个区间中有多少个数字可以整除其他所有区间内的数字. 能够整除其他所有数字的数一定 ...

  4. CF 494 F. Abbreviation(动态规划)

    题目链接:[http://codeforces.com/contest/1003/problem/F] 题意:给出一个n字符串,这些字符串按顺序组成一个文本,字符串之间用空格隔开,文本的大小是字母+空 ...

  5. CF 1138 F. Cooperative Game

    F. Cooperative Game 链接 题意: 有10个玩家,开始所有玩家在home处,每次可以让一些玩家沿着边前进一步,要求在3(t+c)步以内,到达终点. 分析: 很有意思的一道题.我们构造 ...

  6. CF 1041 F. Ray in the tube

    F. Ray in the tube 链接 题意: 有两条平行于x轴的直线A,B,每条直线上的某些位置有传感器.你需要确定A,B轴上任意两个整点位置$x_a$,$x_b$,使得一条光线沿$x_a→x_ ...

  7. 【Cf #502 F】The Neutral Zone

    本题把$log$化简之后求得就是每个质数$f$前的系数,求系数并不难,难点在于求出所有的质数. 由于空间限制相当苛刻,$3e8$的$bitset$的内存超限,我们考虑所有的除了$2$和$3$以外的质数 ...

  8. CF 868 F. Yet Another Minimization Problem

    F. Yet Another Minimization Problem http://codeforces.com/contest/868/problem/F 题意: 给定一个长度为n的序列.你需要将 ...

  9. CF 1051 F. The Shortest Statement

    F. The Shortest Statement http://codeforces.com/contest/1051/problem/F 题意: n个点,m条边的无向图,每次询问两点之间的最短路. ...

随机推荐

  1. M43 第一阶段考试

    一.解答题 1.统计当前主机的TCP协议网络各种连接状态出现的次数 netstat -an | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a ...

  2. (解决)easypoi图片导出只占用一个单元格

    @ 目录 前提 依赖环境 问题原因 解决方案 重写jar中的方法 原理 前提 本解决方案来源于网络,因解决自己需求,因此自行记录起来,如有侵权请联系我. 依赖环境 easypoi--依赖版本3.1.0 ...

  3. 切换用户后whoami打印用户的问题

    问题: 为何第二个whoami打印的还是root? root@localhost /]# [root@localhost /]# [root@localhost /]# more test.sh #! ...

  4. VsCode/Pycharm配合python env 使用

    前言 用惯了vscode,这几天试了一下pycharm,还是回来了. pycharm一个好处就是python env 环境支持的比较好, vscode虽然也支持但是要改一些东西 env的使用查看我的上 ...

  5. 【JDBC核心】操作 BLOB 类型字段

    操作 BLOB 类型字段 MySQL BLOB 类型 MySQL 中,BLOB 是一个二进制大型对象,是一个可以存储大量数据的容器,它能容纳不同大小的数据. 插入 BLOB 类型的数据必须使用 Pre ...

  6. python函数2-函数参数

    rgb法则:

  7. zabbix 监控tomcat

    zabbix 监控tomcat server端rpm -ivh jdk-8u20-linux-x64.rpmvi /etc/profileJAVA_HOME=/usr/java/jdk1.8.0_20 ...

  8. P2024 [NOI2001]食物链(种类并查集)

    题目链接: https://www.luogu.org/problemnew/show/P2024 题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 ...

  9. 面试官:你说说ReentrantLock和Synchronized区别

    大家好!又和大家见面了.为了避免面试尴尬,今天同比较通俗语言和大家聊下ReentrantLock和Synchronized区别! 使用方式 Synchronized可以修饰实例方法,静态方法,代码块. ...

  10. 精通MySQL之架构篇

    老刘是即将找工作的研究生,自学大数据开发,一路走来,感慨颇深,网上大数据的资料良莠不齐,于是想写一份详细的大数据开发指南.这份指南把大数据的[基础知识][框架分析][源码理解]都用自己的话描述出来,让 ...