首页 技术 正文
技术 2022年11月8日
0 收藏 470 点赞 2,312 浏览 1134 个字

CF280C Game on Tree 期望

期望多少次操作,我们可以看做是染黑了多少节点

那么,我们可以用期望的线性性质,求出每个节点被染黑的概率之和(权值为$1$)

一个节点$u$被染黑仅跟祖先有关

我们把$u$到祖先的链抽出来

只要选取链上任意一点,那么我们对节点$u$的染黑的概率就讨论完了

发现链以外的点对这条链的影响都是相同的

也就是说,选取这条链上的一个点的概率都是相同的

因此,选取点$u$的概率就是这条链的节点数的倒数,也就是$\frac{1}{dep_u}$

最后的结果就是对每个点进行求和

$\sum\limits_{1 \leqslant i \leqslant n} \frac{1}{dep_i}$

复杂度$O(n)$

这道题对期望的应用还是挺妙的,并且可扩展性十分的强,挺适合拿来改题的

#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
namespace remoon {
#define de double
#define ri register int
#define tpr template <typename ra>
#define rep(iu, st, ed) for(ri iu = st; iu <= ed; iu ++)
#define drep(iu, ed, st) for(ri iu = ed; iu >= st; iu --)
#define gc getchar
inline int read() {
int p = , w = ; char c = gc();
while(c > '' || c < '') { if(c == '-') w = -; c = gc(); }
while(c >= '' && c <= '') p = p * + c - '', c = gc();
return p * w;
}
}
using namespace std;
using namespace remoon;#define sid 300050int n, cnp;
int cap[sid], nxt[sid], node[sid], dep[sid];
de ans;inline void addedge(int u, int v) {
nxt[++ cnp] = cap[u]; cap[u] = cnp; node[cnp] = v;
}#define cur node[i]
inline void dfs(int o, int fa) {
dep[o] = dep[fa] + ;
ans += / (de)dep[o];
for(int i = cap[o]; i; i = nxt[i])
if(cur != fa) dfs(cur, o);
}int main() {
n = read();
rep(i, , n) {
int u = read(), v = read();
addedge(u, v); addedge(v, u);
}
dfs(, );
printf("%lf\n", ans);
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,489
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,904
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,737
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,490
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,128
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,291