info: { blogIcon: 'https://cdn.luogu.com.cn/upload/usericon/765493.png', blogUser: 'OIerBoy', blogAvatar: 'https://cdn.luogu.com.cn/upload/usericon/765493.png', blogStartDate: '2023-04-22', webpageTitleOnblur: '(o?v?)ノ Hi', webpageTitleOnblurTimeOut: 1000, webpageTitleFocus: '(*′?`*) 欢迎回来!', webpageTitleFocusTimeOut: 1000, webpageIcon: "https://cdn.jsdelivr.net/gh/BNDong/Cnblogs-Theme-SimpleMemory@master/img/webp/blog_logo.webp", { enable: true, // 是否开启日/夜间模式切换按钮 auto: { // 自动切换相关配置 enable: false, // 开启自动切换 dayHour: 5, // 日间模式开始时间,整数型,24小时制 nightHour: 19 // 夜间模式开始时间,整数型,24小时制 } } },

[CF9D]How many trees?

2023-06-01

题目

题目传送门

难度&重要性(1~10):5

题目来源

Codeforces,luogu

题目算法

dp

解题思路

深度最大为 \(n\left(1\le n\le 35\right)\) 的二叉树暴力枚举显然不行,考虑dp。
\(f_{i,j}\) 表示有 \(i\) 个节点时,深度不大于 \(j\) 的二叉树数量。
答案容斥:\(f_{n,n}-f_{n,h-1}\)
这里,我们可以枚举 \(i-1\) 的左右儿子数量的状况来转移:

\[f_{i,j}=\sum\limits_{k=0}^if_{k,j-1}\cdot f_{i-k-1,j-1} \]

注意,这里我们要先枚举 \(j\),再枚举 \(i\),以保证前面的状态都已经枚举过。

完成状态

已完成

posted @ 2023-06-01 10:11  OIerBoy  阅读(13)  评论(0)    收藏  举报