poj 1095 题解(卡特兰数+递归
题意:给出一个二叉树的编号,问形态。
编号依据
1:如果二叉树为空,则编号为0;
2:如果二叉树只有一个节点,则编号为1;
3:所有含有m个节点的二叉树的编号小于所有含有m+1个节点的二叉树的编号;
4:如果一棵含有m个节点的二叉树(左子树为L,右子树为R)的编号为n,要想其它含有m个节点的二叉树的编号如果大于n,则需要满足两个条件中的任意一个:1、左子树的编号大于L的左子树的编号等于L的编号,但是右子树的编号大于R的编号。(大概就是先将右子树的个数填满将变幻完后再将右子树的点向左子树转移
一道卡特兰数的题。。总的来说代码难度不高,但是思维难度还是挺高的,首先二叉树形态有几种就很想然得想到用卡特兰数啦。
递推公式
$ cat[i]=cat[i-1]* ( 4 * i-2)/(i+1) \ \ \ \ \ cat[1]=1,cat[0]=1 $
不了解的自行百度卡特兰数
我们首先可以设一棵二叉树可能的形态种类数为 $ f[n] $ 那么对于左子数所含有的节点数 $ 0<=i<=n-1 $ 都有 $ f[n]= \sum_{i = 0}^{n-1}\ f[i] * f[n-i-1] $
首先我们设当前含有x个节点的二叉树第order个排序通给定数 $ n $ 计算出当前有几个节点并且当前是第几个排序 $ order=n-Catalan(0)+Catalan(1)+...+Catalan(i-1)) \ \ \ \ (Catalan(i)>=n)) $
然后我们再去考虑二叉树中左子树有多少个节点,右子树有多少节点。由题意知初始状态下,左子树为空,所有的节点均在右子树上并且所有节点只有右孩子,随着右子树的变化完后,右子树拿一个节点到左子树,然后再变化。这个过程就像时钟一样,右子树是分钟,左子树是时针,右子树的变化走满了,就开始进位,然后左子树再变化。当然这里使用的进制当然就是卡特兰数进制呀。然后只要算出左右此时的节点个数以及是第几个排序。之后层层递归下去即可。
代码
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=500000010;
int n;
long long cat[40],sum[40];
void star(){
cat[0]=cat[1]=1;
for(int i=2;i<35;++i){
cat[i]=cat[i-1]*(4*i-2)/(i+1);
}
return;
}
void find(int x,int order){
if(x==1){
printf("X");
return;
}int i,cnt=0;
for(i=0;cnt<order;i++){//保证左子树尽可能小
cnt+=cat[i]*cat[x-i-1];
}i--;
int l=i,r=x-l-1;
int neworder=order-(cnt-cat[l]*cat[r]);//减去其中的个数
if(l>0){
printf("(");
find(l,(neworder-1)/cat[r]+1);//减一然后在后面加一相当于判断是否有余数,有余数加一
printf(")");
}printf("X");
if(r>0){
printf("(");
find(r,(neworder-1)%cat[r]+1);//同上
printf(")");
}
}
int main(){
star();
while(scanf("%d",&n)&&n){
int i,cnt=0;
for(i=1;cnt<n;++i){
cnt+=cat[i];
}i--;
find(i,n-(cnt-cat[i]));
printf("\n");
}
return 0;
}
poj 1095 题解(卡特兰数+递归的更多相关文章
- HDU-4828 卡特兰数+带模除法
题意:给定2行n列的长方形,然后把1—2*n的数字填进方格内,保证每一行,每一列都是递增序列,求有几种放置方法,对1000000007取余: 思路:本来想用组合数找规律,但是找不出来,搜题解是卡特兰数 ...
- poj 1095 Trees Made to Order 卡特兰数
这题用到了卡特兰数,详情见:http://www.cnblogs.com/jackge/archive/2013/05/19/3086519.html 解体思路详见:http://blog.csdn. ...
- FZU 1064 教授的测试(卡特兰数,递归)
Problem 1064 教授的测试 Accept: 149 Submit: 364 Time Limit: 1000 mSec Memory Limit : 32768 KB Problem Des ...
- [SCOI2010]生成字符串 题解(卡特兰数的扩展)
[SCOI2010]生成字符串 Description lxhgww最近接到了一个生成字符串的任务,任务需要他把n个1和m个0组成字符串,但是任务还要求在组成的字符串中,在任意的前k个字符中,1的个数 ...
- [HNOI2009]有趣的数列 题解(卡特兰数)
[HNOI2009]有趣的数列 Description 我们称一个长度为2n的数列是有趣的,当且仅当该数列满足以下三个条件: (1)它是从1到2n共2n个整数的一个排列{ai}: (2)所有的奇数项满 ...
- [AHOI2012]树屋阶梯 题解(卡特兰数)
[AHOI2012]树屋阶梯 Description 暑假期间,小龙报名了一个模拟野外生存作战训练班来锻炼体魄,训练的第一个晚上,教官就给他们出了个难题.由于地上露营湿气重,必须选择在高处的树屋露营. ...
- [NOIP2003]栈 题解(卡特兰数)
[NOIP2003]栈 Description 宁宁考虑的是这样一个问题:一个操作数序列,从1,2,一直到n(图示为1到3的情况),栈A的深度大于n. 现在可以进行两种操作: 1.将一个数,从操作数序 ...
- POJ 2084 Game of Connections 卡特兰数
看了下大牛们的,原来这题是卡特兰数,顺便练练java.递归式子:h(0)=1,h(1)=1 h(n)= h(0)*h(n-1) + h(1)*h(n-2) + ... + h(n-1)h(0) ( ...
- POJ 2084 Game of Connections(卡特兰数)
卡特兰数源于组合数学,ACM中比较具体的使用例子有,1括号匹配的种数.2在栈中的自然数出栈的种数.3求多边形内三角形的个数.4,n个数围城圆圈,找不相交线段的个数.5给定n个数,求组成二叉树的种数…… ...
随机推荐
- Github搭建简单的博客
1)安装pelcan和markdown pip install pelican markdown --upgrade 2)创建一个文件夹用来作为博客的目录 mkdir 博客目录 3)cd到该目录下运行 ...
- js傻瓜式制作电子时钟
js傻瓜式制作电子时间 使用到的知识点 setInterval函数 构建函数new Date if判断 demo: //css样式请自行设置 <span id="timer" ...
- C++编译器和连接器原理
本文转载自新浪永远即等待的博客 几个概念: 1.编译:编译器对源文件进行编译,就是把源文件中的文本形式存在的源代码翻译成机器语言形式的目标文件的过程,在这个过程中,编译器会进行一系列的语法检查.如果 ...
- Redis存储Set
与List不同Set不能存储相同元素,且数据没有顺序. 存储结构: 1.存储与查看数据: 2.删除指定的一个元素: 3.判断是否存在某一个元素(存在返回1,不存在返回0): 4.判断两个set中的特有 ...
- C# 监测每个方法的执行次数和占用时间(测试4)
今天也要做这个功能,就百度一下,结果搜索到了自己的文章.一开始还没注意,当看到里面的一个注释的方法时,一开始还以为自己复制错了代码,结果仔细一看网页的文章,我去,原来是自己写的,写的确实不咋地. 把自 ...
- 洛谷 P1474 货币系统 Money Systems 题解
P1474 货币系统 Money Systems 题目描述 母牛们不但创建了它们自己的政府而且选择了建立了自己的货币系统.由于它们特殊的思考方式,它们对货币的数值感到好奇. 传统地,一个货币系统是由1 ...
- [USACO5.1]二维凸包模板
传送门 Description 求\(n\)个点凸包的周长 Solution 计算几何打暴力必备 Code #include<bits/stdc++.h> #define reg re ...
- 【POJ1068】Parencodings
题目传送门 本题知识点:模拟 这是一道恐怖的括号题.题意稍微理解以下还是可以的. 我们针对样例来理解一下 S.P.W 到底是什么意思: S:( ( ( ( ) ( ) ( ) ) ) ) P: \(P ...
- python中的函数---函数应用
每种编程语言中,都需要函数的参与,python同样也不例外.函数是集成的子程序,是算法实现的最小方法单位,是完成基本操作的手段的集合.编程中能够灵活应用函数,提高程序设计的简单化:实现代码应用的复用化 ...
- how does SELECT TOP works when no order by is specified?
how does SELECT TOP works when no order by is specified? There is no guarantee which two rows you ge ...