3112 二叉树计数

题目描述 Description

一个有n个结点的二叉树总共有多少种形态

输入描述 Input Description

读入一个正整数n

输出描述 Output Description

输出一个正整数表示答案

样例输入 Sample Input

6

样例输出 Sample Output

132

数据范围及提示 Data Size & Hint

1<=n<=20

/*
  假设该二叉树的左子树有i个节点,则右子树有n-i-1个节点
  用fs(n)表示n个节点的二叉树不同的形态数,则左子树和柚子树就可以递归的表示为fs(i)和fs(n-i-1)
  再根据乘法原理,总的答案即为fs(i)*fs(n-i-1) (i=0~n-1)
*/
#include<iostream>
#include<cstdio>
using namespace std;
#define ll long long
ll n,f[];
ll fs(ll x){
if(x==)return ;
if(x==)return ;
if(x==)return ;
if(f[x])return f[x];
ll sum=;
for(ll i=;i<=x-;i++){
sum+=fs(i)*fs(x-i-);
}
f[x]=sum;
return f[x];
}
int main(){
scanf("%lld",&n);
printf("%lld",fs(n));
}

最新文章

  1. 【转】DBMS_STATS.GATHER_TABLE_STATS详解
  2. GET/POST请求(NSURLSession)
  3. windows下C语言编程获取磁盘(分区)使用情况
  4. linux命令每日一练习-rmdir mv
  5. Java基础之-ExecutorService
  6. JavaScript 最佳实践
  7. Java Phaser
  8. C#操作Excel数据增删改查(转)
  9. Boot Repair-能一键修复ubuntu启动/引导项的软件(告别命令行)
  10. line-height让文本在块级元素中居中显示总结
  11. C++之算法题模板
  12. JavaScript 时间显示
  13. 迁移笔记:对ob_start()的总结
  14. CentOS的改变系统启动级别
  15. 【Win10】正常上网但ping不通外网
  16. scrapy爬取58同城二手房问题与对策
  17. day 7-3 僵尸进程,孤儿进程与守护进程
  18. python之 协程
  19. HDU 1014 Uniform Generator(题解)
  20. redis常用客户端命令

热门文章

  1. 九度OJ 1129:Skew数 (大数运算)
  2. jvm -Xms -Xmx
  3. root无权限删除 原因 进程 占用 文件
  4. BZOJ 2069 POI2004 ZAW 堆优化Dijkstra
  5. ABAP DEMO-2018
  6. MySQL学习笔记(六)—— MySQL自连接
  7. 为 Android 平台开发一个输入法
  8. 脚踏实地学C#3-装箱和拆箱
  9. Awesome Flask Awesome
  10. java并发之阻塞队列LinkedBlockingQueue与ArrayBlockingQueue