Codevs 3112 二叉树计数

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[30];
ll fs(ll x){
    if(x==0)return 1;
    if(x==1)return 1;
    if(x==2)return 2;
    if(f[x])return f[x];
    ll sum=0;
    for(ll i=0;i<=x-1;i++){
        sum+=fs(i)*fs(x-i-1);
    }
    f[x]=sum;
    return f[x];
}
int main(){
    scanf("%lld",&n);
    printf("%lld",fs(n));
}
时间: 2024-08-27 17:21:25

Codevs 3112 二叉树计数的相关文章

[Catalan数]1086 栈、3112 二叉树计数、3134 Circle

1086 栈 2003年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表. 栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈). 栈的重要性不言自明,任何一门数据结构的课程都会介绍栈.宁宁同学在复习栈的基本概念时,想到了一个书上没有讲过的问题,而他自己无法给出答案,所以需要你的帮忙 宁宁考虑的

【codevs】3112 二叉树计数

时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个有n个结点的二叉树总共有多少种形态 输入描述 Input Description 读入一个正整数n 输出描述 Output Description 输出一个正整数表示答案 样例输入 Sample Input 6 样例输出 Sample Output 132 数据范围及提示 Data Size & Hint 1<=n<=20 分析 catalan数 f[2]=f[3]=

1180. 二叉树计数

180. 二叉树计数 (Standard IO) 时间限制: 1000 ms  空间限制: 262144 KB  具体限制 题目描述 n个相同结点构成的二叉树有多少种?如3个结点的二叉树有以下5种: 输入 第一行输入n(1<=n<=30),表示结点数. 输出 输出一个整数表示二叉树的种数. 样例输入 3 样例输出 5 数据范围限制 1<=n<=30 1 #include<iostream> 2 using namespace std; 3 long long int f

二叉树计数(codevs 3112)

题目描述 Description 一个有n个结点的二叉树总共有多少种形态 输入描述 Input Description 读入一个正整数n 输出描述 Output Description 输出一个正整数表示答案 样例输入 Sample Input 6 样例输出 Sample Output 132 数据范围及提示 Data Size & Hint 1<=n<=20 /* 复习一下卡特兰数,以备考试考上模板(虽然可能性不大) 递推式:h[1]=1,h[i]=(4*i-2)*h[i-1]/(n

Codevs 1501 二叉树的最大宽度和高度

1501 二叉树最大宽度和高度 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 Description 给出一个二叉树,输出它的最大宽度和高度. 输入描述 Input Description 第一行一个整数n. 下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号.如果没有某个儿子为空,则为0. 输出描述 Output Description 输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开. 样例输入 Sa

codevs——1501 二叉树最大宽度和高度

1501 二叉树最大宽度和高度 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题解 题目描述 Description 给出一个二叉树,输出它的最大宽度和高度. 输入描述 Input Description 第一行一个整数n. 下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号.如果没有某个儿子为空,则为0. 输出描述 Output Description 输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开. 样例输入

CODEVS 1501二叉树最大宽度和高度

题目描述 Description 给出一个二叉树,输出它的最大宽度和高度. 输入描述 Input Description 第一行一个整数n. 下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号.如果没有某个儿子为空,则为0. 输出描述 Output Description 输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开. 样例输入 Sample Input 5 2 3 4 5 0 0 0 0 0 0 样例输出 Sample Output 2 3 数据范

codevs 3083 二叉树

题目描述 Description 同学们都知道二叉树的定义,也都知道3个结点的二叉树有5种, 现给你二叉树的结点个数n,要你编程输出不同形态二叉树的种数. 输入描述 Input Description 一个整数n 输出描述 Output Description 不同形态二叉树的种数. 样例输入 Sample Input 3 样例输出 Sample Output 5 数据范围及提示 Data Size & Hint n<30 讨论过程:http://www.cnblogs.com/huasha

codevs 1501 二叉树最大宽度和高度x

题目描述 Description 给出一个二叉树,输出它的最大宽度和高度. 输入描述 Input Description 第一行一个整数n. 下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号.如果没有某个儿子为空,则为0. 输出描述 Output Description 输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开. 样例输入 Sample Input 5 2 3 4 5 0 0 0 0 0 0 样例输出 Sample Output 2 3 数据范