codevs 3083 二叉树

简介: 题目描述 Description同学们都知道二叉树的定义,也都知道3个结点的二叉树有5种,现给你二叉树的结点个数n,要你编程输出不同形态二叉树的种数。输入描述 Input Description一个整数n输出描述 Output Description不同形态二叉树的种数。
题目描述 Description

同学们都知道二叉树的定义,也都知道3个结点的二叉树有5种,

现给你二叉树的结点个数n,要你编程输出不同形态二叉树的种数。

输入描述 Input Description
一个整数n
输出描述 Output Description

不同形态二叉树的种数。

样例输入 Sample Input

3

样例输出 Sample Output

5

数据范围及提示 Data Size & Hint

n<30

讨论过程:http://www.cnblogs.com/huashanqingzhu/p/5823166.html

http://www.cnblogs.com/hujunzheng/p/5040334.html

 1 #include <iostream>
 2 using namespace std;
 3 int main()
 4 {
 5     long long n,i;
 6     long long h0=1,h1=1,h2;
 7     cin>>n;
 8     if(n==0||n==1) cout<<1<<endl;
 9     else
10     {
11         for(i=2;i<=n;i++)
12         {
13             h2=(4*i-2)*h1/(i+1);
14             h1=h2;
15             //cout<<h2<<endl;
16         }
17         cout<<h2<<endl;
18     }
19     return 0;
20 }

另一个做法,思路不谋而合:

何泓历的代码:

 1 #include <stdio.h>
 2 long long a[21]={0};
 3 long long fun(int n)
 4 {
 5     if(n==1||n==0) return 1;
 6     long long sum=0,i;
 7     for(i=0;i<n;i++)
 8     {
 9         if(a[i]==0) a[i]=fun(i);
10         if(a[n-1-i]==0) a[n-1-i]=fun(n-1-i);
11         sum+=a[i]*a[n-1-i];
12     }
13     return sum;
14 }
15 int main()
16 {
17     int n;
18     scanf("%d",&n);
19     printf("%lld\n",fun(n));
20     return 0;
21 }

 

 

 

相关文章
|
9月前
|
存储 容器
AVL树的实现(万字图文详解)
AVL树的实现(万字图文详解)
85 1
篇一:二叉树-遍历终极版
篇一:二叉树-遍历终极版
|
4月前
|
存储 算法
【408数据结构与算法】—树和二叉树(二十七)
【408数据结构与算法】—树和二叉树(二十七)
|
10月前
|
算法
代码随想录算法训练营第十九天 | LeetCode 654. 最大二叉树、617. 合并二叉树、700. 二叉搜索树中的搜索、98. 验证二叉搜索树
代码随想录算法训练营第十九天 | LeetCode 654. 最大二叉树、617. 合并二叉树、700. 二叉搜索树中的搜索、98. 验证二叉搜索树
53 0
|
存储
二叉树的基本操作(C 语言版)
二叉树的基本操作(C 语言版)
40 1
leetcode105/1382-构建二叉树与二叉平衡树(人生苦短,速速递归)
leetcode105/1382-构建二叉树与二叉平衡树(人生苦短,速速递归)
leetcode105/1382-构建二叉树与二叉平衡树(人生苦短,速速递归)
二叉树模板套题——相同的树的应用
二叉树模板套题——相同的树的应用
54 0
|
存储 Java Python
【剑指 の 精选】详解「二叉树中序遍历的下一个结点」两种解法 |Python 主题月
【剑指 の 精选】详解「二叉树中序遍历的下一个结点」两种解法 |Python 主题月
|
机器学习/深度学习
LeetCode-104. 二叉树的最大深度(Goland实现)
LeetCode-104. 二叉树的最大深度(Goland实现)
92 0
|
存储 人工智能 算法
codevs 3143 二叉树的序遍历
codevs 3143 二叉树的序遍历 题目描述 Description 求一棵二叉树的前序遍历,中序遍历和后序遍历 输入描述 Input Description 第一行一个整数n,表示这棵树的节点个数。
1026 1