[SHOI2012]随机树

题目大意( 网址戳我! )

随机树是一颗完全二叉树,初始状态下只有一个节点。
随机树的生成如下:每次随机选择一个叶子节点,扩展出两个儿子。
现在给定一个正整数\(n\)(\(n \le 100\)) , 询问叶子节点个数为\(n\)的随机树:

  • \(q = 1\) :叶子节点的平均深度
  • \(q = 2\) :整棵随机树的平均深度

样例:\(cin\ q\ n\ \ \ \ ;cin\ 1\ 4\ ,\ put\ 2.166667\ \ \ ;\ \ \ cin \ 2 \ 4\ ,\ put\ 2.666667\ \ \ ;\)

解题思路

\(solve_a\): \(q = 1\) (叶子节点平均深度)

设\(f(x)\)表示扩展了\(x\)次后的叶子节点平均深度。
那么求\(f(x)\)时 , 直接把新扩展的节点深度设为 \(f(x-1)\) 不就行了吗?
转移:
\(f(x) = \frac{1}{x} (\ f(x-1)*(x-1) - f(x - 1) + (f(x-1)+1)*2\ )\)
把它展开后:
\(f(x) = f(x - 1) + \frac{2}{x}\) , 初始值:\(f(0) = 0\) ;

\(solve_b\): \(q = 2\) (整棵树的平均深度)

整数概率公式:\(E(x) = \sum_{i=1}^{\infty} P(x \ge i)\)
所以只要求随机树层数大于等于\(i\)层的概率即可。
我们脱离扩展,改为构建一颗有\(n\)个叶子节点,问层数大于等于\(i\)层的概率。
设\(f[x][d]\)表示有\(x\)个叶节点,树深度大于等于\(d\)的概率。
那么每次通过添加根来提升层数 , 枚举左右儿子分配多少个叶子节点即可。
转移:
\[f[x][d] = \frac{1}{x-1}\sum_{i=1}^{x-1} = f[i][d-1] + f[x-i][d-1] - f[i][d-1]*f[x-i][d-1]\]
就是小学容斥原理 , 然后初值为:\(f[x][0] = 1.0\)

实现代码:

#include<bits/stdc++.h>
#define RG register
#define IL inline
#define _ 101
using namespace std;

double f[_][_],res,ans; int q , n ; 

IL void solve1(){
    for(RG int i = 2; i <= n; i ++) res += 2.0 / (double)i ;
    printf("%.6lf" , res) ;  return ;
}
IL void solve2(){
    for(RG int x = 1; x <= n; x ++)f[x][0] = 1.0;
    for(RG int x = 2; x <= n; x ++)
        for(RG int d = 1; d <= x ; d ++){
            for(RG int l = 1; l <= x - 1; l ++)
                f[x][d] += f[l][d-1] + f[x-l][d-1] - f[l][d-1]*f[x-l][d-1] ;
            f[x][d] /= (double)(x - 1) ;
        }
    ans = 0; for(RG int i = 1; i <= n; i ++)ans += f[n][i] ;
    printf("%.6lf" , ans) ;  return ;
}

int main(){
    cin >> q ; cin >> n;
    (q & 1) ? solve1() : solve2() ;
    return 0;
}

[SHOI2012]随机树的更多相关文章

  1. P3830 [SHOI2012]随机树 题解

    P3830 随机树 坑题,别人的题解我看了一个下午没一个看得懂的,我还是太弱了. 题目链接 P3830 [SHOI2012]随机树 题目描述 输入输出格式 输入格式: 输入仅有一行,包含两个正整数 q ...

  2. P3830 [SHOI2012]随机树

    P3830 [SHOI2012]随机树 链接 分析: 第一问:f[i]表示有i个叶子结点的时候的平均深度,$f[i] = \frac{f[i - 1] + 2 + f[i - 1] * (i - 1) ...

  3. bzoj2830: [Shoi2012]随机树

    题目链接 bzoj2830: [Shoi2012]随机树 题解 q1好做 设f[n]为扩展n次后的平均深度 那么\(f[n] = \frac{f[n - 1] * (n - 1) + f[n - 1] ...

  4. luogu P3830 [SHOI2012]随机树 期望 dp

    LINK:随机树 非常经典的期望dp. 考虑第一问:设f[i]表示前i个叶子节点的期望平均深度. 因为期望具有线性性 所以可以由每个叶子节点的期望平均深度得到总体的. \(f[i]=(f[i-1]\c ...

  5. luogu3830 [SHOI2012]随机树

    传送门:洛谷 题目大意:对于一个只有一个节点的二叉树,一次操作随机将这棵树的叶节点的下方增加两个节点.$n-1$次操作后变为$n$个叶节点的二叉树.求:(1)叶节点平均深度的期望值(2)树深度的数学期 ...

  6. luogu P3830 [SHOI2012]随机树

    输入格式 输入仅有一行,包含两个正整数 q, n,分别表示问题编号以及叶结点的个数. 输出格式 输出仅有一行,包含一个实数 d,四舍五入精确到小数点后 6 位.如果 q = 1,则 d 表示叶结点平均 ...

  7. [SHOI2012]随机树[期望dp]

    题意 初始 \(1\) 个节点,每次选定一个叶子节点并加入两个儿子直到叶子总数为 \(n\),问叶子节点深度和的平均值的期望以及最大叶子深度的期望. \(n\leq 100\) . 分析 对于第一问, ...

  8. 洛谷P3830 [SHOI2012]随机树(期望dp)

    题面 luogu 题解 第一问: 设\(f[i]\)表示\(i\)步操作后,平均深度期望 \(f[i] = \frac {f[i - 1] * (i - 1)+f[i-1]+2}{i}=f[i-1]+ ...

  9. 【[SHOI2012]随机树】

    感觉第一问就非常神仙,还有第二问怎么被我当成组合数学题来做了 首先是第一问 期望具有线性性,于是深度平均值的期望等于深度和的期望值的平均 设\(dp_x\)表示具有\(x\)个叶子节点的树的深度和的期 ...

随机推荐

  1. memcached 与 redis 的区别和具体应用场景

    1. Memcached简介 Memcached是以LiveJurnal旗下Danga Interactive公司的Bard Fitzpatric为首开发的高性能分布式内存缓存服务器.其本质上就是一个 ...

  2. 关于 iOS 分类(Category)的实现代码

    其实质是对一个类的扩充,对类扩充的方法有两种: (1)通过继承(经常用到) (2)通过分类 一个已知类Name 其头文件Name.h #import <Foundation/Foundation ...

  3. Fiddler使用简单介绍

     一,fiddler简介 1.1,什么是fiddler Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的"进出&qu ...

  4. DB2物化视图——MQT 物化查询表的正确使用(materialized query tables)

    我们今天主要向大家讲述的是DB2物化视图——MQT 物化查询表使用,以下就是对DB2物化视图之MQT物化查询表的正确使用的主要内容的详细描述,望大家在浏览之后会对其有更深的了解. MQT 的定义基于查 ...

  5. 隐藏文件的查看(Win/Linux/macOS)

    Windows(10): 点查看->点选项,弹出文件夹选项,点查看,高级设置里找到隐藏文件和文件夹这个选项,按需求选显示或者隐藏即可. Linux: Linux下,类似于.ssh开头的文件或者文 ...

  6. Docker镜像的构成__Dockerfile

    相比docker commit来说,Dockerfile的方法会更加自动化,更加方便快捷,而且功能也更强大.拿构建Nginx容器举例. 先创建一个目录 mkdir /opt/docker-file 进 ...

  7. 生成1~n的排列

    直接递归打印. 代码如下 #include<cstdio> void dfs(int *a,int cur,int n) { if(cur==n) { for(int i=0;i<n ...

  8. node实现jsonp跨域

    1. 搭建node server //引入模块 var http=require("http"); var fs=require("fs");var url = ...

  9. Django2.0文档

    第四章 模板 1.标签 (1)if/else {% if %} 标签检查(evaluate)一个变量,如果这个变量为真(即,变量存在,非空,不是布尔值假),系统会显示在 {% if %} 和 {% e ...

  10. javascript获取网页地址栏的id

    //获取网页的uid (function ($) { $.getUrlParam = function (name) { var reg = new RegExp("(^|&)&qu ...