[CF280C]Game on Tree

题目大意:给出一棵树,每次随机等概率选择一未染黑的点,将它及其子树染黑。问期望多少次操作可以将树全部染黑。

题解:一个点被染黑的可能是它的父亲或它自己中的一个被染黑,所以它给出贡献的概率是它深度的倒数,累加即可

卡点:

 

C++ Code:

#include <cstdio>
#define maxn 100010

int head[maxn], cnt;
struct Edge {
	int to, nxt;
} e[maxn << 1];
inline void add(int a, int b) {
	e[++cnt] = (Edge) {b, head[a]}; head[a] = cnt;
}

int n, fa[maxn], dep[maxn];
double ans;
void dfs(int u) {
	ans += 1.0 / dep[u];
	for (int i = head[u]; i; i = e[i].nxt) {
		int v = e[i].to;
		if (v != fa[u]) {
			dep[v] = dep[u] + 1;
			fa[v] = u;
			dfs(v);
		}
	}
}

int main() {
	scanf("%d", &n);
	for (int i = 1, a, b; i < n; i++) {
		scanf("%d%d", &a, &b);
		add(a, b);
		add(b, a);
	}
	dep[1] = 1; dfs(1);
	printf("%.7lf\n", ans);
	return 0;
} 

  

posted @ 2018-10-10 15:32  Memory_of_winter  阅读(162)  评论(0编辑  收藏  举报