本文主要是介绍PKU Online Judge 1055:Tree,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1055:Tree
- 查看
- 提交
- 统计
- 提问
- 总时间限制:
- 2000ms 内存限制:
- 131072kB
- 描述
-
在信息学竞赛中,我们经常要遇到树这种结构。
一棵树中除根结点外有且仅有一个父亲,而可能有很多儿子。所以,当我们要生成一棵树的时候,我们通常使用以下算法:
对树中的每个点定义一个深度。第 1 个节点的深度为 1,第 i 个点的深度就是 Fatheri的深度加 1 。
有一天,Picks突然对这个算法产生了强烈的兴趣,他想知道,在随机函数完全公平的情况下,给出树的节点数最大值的限制 N ,从所得的树上任选一个节点,其深度的期望是多少?
数据范围
评测方式
对于每个测试点,你给出的答案需满足以下不等式才能获得该测试点的分数。
输入 - 一个测试点中有多组数据(不超过10组)。对于每组数据:
一行,仅有一个数: N. 输出 - 对于每组数据:
一行,仅有一个数,即答案。 样例输入 -
1 2
样例输出 -
1.0000000000 1.2500000000
提示 - 1个结点时,结点深度的期望是1。
2个结点时,结点深度的期望是1.5。
样例2中,0.5的几率Nodes=1,0.5的几率Nodes=2. - 考虑生成一个有M 个结点的树。
设fi 表示第i 个结点的期望深度,Ei 表示前i 个结点构成的树的平均
深度。
-
#include <iostream> #include <stdio.h> #include <math.h> #include <string.h> using namespace std; #define M 2000000 double pri[M]; int main() {int i;for(pri[0]=0,i=1;i<M;i++){pri[i]=pri[i-1]+1.0/i;}double temp,la=pri[M-1]-log(1.0*M);long long n;while(scanf("%lld",&n)!=EOF){if(n<M)temp=pri[n];else temp=log(1.0*(n+1))+la;printf("%.10f\n",temp*(n+1)/n-1.0);}return 0; }
这篇关于PKU Online Judge 1055:Tree的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!