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/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 }
时间: 2024-11-06 15:50:34

codevs 3083 二叉树的相关文章

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 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 数据范

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个节点的二叉树不同的

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

时间限制: 1 s 空间限制: 128000 KB 题目等级: 白银 Silver 点此跳转 [题目描述] 给出一个二叉树,输出它的最大宽度和高度. [输入描述] 第一行一个整数n. 下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号.如果没有某个儿子为空,则为0. [输出描述] 输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开. [样例输入] 5 2 3 4 5 0 0 0 0 0 0 [样例输出] 2 3 [数据范围及提示] n<16默认第一个是根节

codevs 3143 二叉树的序遍历

递归 #include <iostream> #include <vector> #include <sstream> #include <string> #include <cmath> #include <stack> using namespace std; int pan[17]={0}; int l[17]; int r[17]; ///先根访问节点, ///对节点是访问 对树是遍历子树 ///最简单的访问shi输出 voi

2016.6.12 codevs搜索练习

1.codevs 3143 二叉树的序遍历 1 /*只要把输出根节点的位置调换一下就可以了*/ 2 #include<iostream> 3 using namespace std; 4 #include<cstdio> 5 #define N 20 6 struct node{ 7 int l,r; 8 }tree[N]; 9 int n; 10 int rudu[N]; 11 void pre_search(int k) 12 { 13 printf("%d &quo

二叉树结构 codevs 1029 遍历问题

codevs 1029 遍历问题 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 我们都很熟悉二叉树的前序.中序.后序遍历,在数据结构中常提出这样的问题:已知一棵二叉树的前序和中序遍历,求它的后序遍历,相应的,已知一棵二叉树的后序遍历和中序遍历序列你也能求出它的前序遍历.然而给定一棵二叉树的前序和后序,你却不能确定其中序遍历序列,考虑如下图中的几棵二叉树: 所有这些二叉树都有着相同的前序遍历和后序遍历,但中序遍历却不相同.