卡特兰数(Catalan Number) 学习笔记
一、三个简单的问题
1.给定一串长为2n的01序列,其中0和1的数量相等,满足任意前缀中0的个数不少于1的个数,求序列的个数
2.给出一串长为n的序列,按顺序将他们进栈,随意出栈,求最后进出栈的方案
3.给定一个n个节点的二叉树,求二叉树有多少种(这里定义不同指树的形态不同)
这三个问题都有关catalan数
事实上关于Catalan的性质有关问题很多,这里只是比较针对的列出了几种。
二、求解问题1
稍微想一想及可以知道,问题1,2同构,问题3却好像不一样。
我们以问题1为例,推出卡特兰数的计算式。
很简单的容斥原理,我们先求出所有的序列,然后减去不合法的序列即是答案
所有序列个数直接根据组合数的定义为\(C_{2n}^n\)
关于不合法的序列,我们先介绍结论,然后进行证明
满足存在一个前缀使得1的个数大于0的个数的 n个0与n个1构成的01序列与n+1个0与n-1个1构成的01序列 构成一个双射,即11对应关系
很显然,后者的数量为\(C_{2n}^{n-1}\)
证明:
对前者,很显然可以找到一个位置为\(2p+1\)的前缀,使得其中有\(p+1\)个\(1\)和\(p\)个\(0\),好的我们把它取反,即得到了后者
对后者,同样我们可以找到一个位置为\(2p+1\)的前缀,使得其中有\(p\)个\(1\)和\(p+1\)个\(0\)(\(0\)比\(1\)多我们一定可以找到),然后取反,得到前者
综上所述,我们得到了卡特兰数的计算公式1
\[Cat_n=C_{2n}^n-C_{2n}^{n-1}\]
化简搞一搞
\[Cat_n=\frac{C_{2n}^n}{n+1}\]
可以继续推出递推式
\[Cat_n=\frac{2(2n-1)}{n+1}Cat_{n-1}\]
对递推式\(Cat_0=1\)
事实上,计算时求有组合数的那个用的比较多。
三、求解问题3
很抱歉有一步的证明不能给出,一是网上没找到,二是听说比较难
对于问题3,我们发现它本身介绍一个可以递归求解的子问题,设方案数为\(h(n)\)。
我们随便选取一点作为根(点都是相同的),则分别讨论左右子树的大小即可
显然有
\[h(n)=\sum_{i=0}^n h(i) \times h(n-1-i)\]
\[h(0)=h(1)=1\]
经过证明,\(h(n)=Cat_n\)
于是对于递推式是这样的题目,我们也可以使用卡特兰数解决。
可能会更新一些题目...
参考资料:算法竞赛进阶指南,网上的博客
卡特兰数(Catalan Number) 学习笔记的更多相关文章
- 浅谈卡特兰数(Catalan number)的原理和相关应用
一.卡特兰数(Catalan number) 1.定义 组合数学中一个常出现在各种计数问题中出现的数列(用c表示).以比利时的数学家欧仁·查理·卡特兰的名字来命名: 2.计算公式 (1)递推公式 c[ ...
- 卡特兰数 catalan number
作者:阿凡卢 出处:http://www.cnblogs.com/luxiaoxun/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留 ...
- 卡特兰数(Catalan Number) 算法、数论 组合~
Catalan number,卡特兰数又称卡塔兰数,是组合数学中一个常出现在各种计数问题中出现的数列.以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)命名. 卡特兰数的前几个数 前20项为( ...
- 【知识总结】卡特兰数 (Catalan Number) 公式的推导
卡特兰数的英文维基讲得非常全面,强烈建议阅读! Catalan number - Wikipedia (本文中图片也来源于这个页面) 由于本人太菜,这里只选取其中两个公式进行总结. (似乎就是这两个比 ...
- [LeetCode系列]卡特兰数(Catalan Number) 在求解独特二叉搜寻树(Unique Binary Search Tree)中的应用分析
本文原题: LeetCode. 给定 n, 求解独特二叉搜寻树 (binary search trees) 的个数. 什么是二叉搜寻树? 二叉查找树(Binary Search Tree),或者是一棵 ...
- 卡特兰数 Catalan数 ( ACM 数论 组合 )
卡特兰数 Catalan数 ( ACM 数论 组合 ) Posted on 2010-08-07 21:51 MiYu 阅读(13170) 评论(1) 编辑 收藏 引用 所属分类: ACM ( 数论 ...
- 卡特兰数 Catalan 笔记
一.公式 卡特兰数一般公式 令h(0)=1,h(1)=1,catalan数满足递推式.h(n) = h(0)*h(n-1)+h(1)*h(n-2) + ... + h(n-1)h(0) (n>= ...
- 【2020.12.01提高组模拟】卡特兰数(catalan)
题目 题目描述 今天,接触信息学不久的小\(A\)刚刚学习了卡特兰数. 卡特兰数的一个经典定义是,将\(n\)个数依次入栈,合法的出栈序列个数. 小\(A\)觉得这样的情况太平凡了.于是,他给出了\( ...
- 卡特兰数(Catalan)及其应用
卡特兰数 大佬博客https://blog.csdn.net/doc_sgl/article/details/8880468 卡特兰数是组合数学中一个常出现在各种计数问题中出现的数列. 卡特兰数前几项 ...
随机推荐
- 多台服务器下同步文件夹数据(rsync+inotify)
网上有很多讲解rsync+inotify的教程,我就先贴出一个来大家去看吧,基本都是类似的. http://www.jb51.net/article/57011.htm 我就强调几点,按照上面的方法配 ...
- 快速写一个babel插件
es6/7/8的出现,给我们带来了很多方便,但是浏览器并不怎么支持,目前chrome应该是支持率最高的,所以为了兼容我们只能把代码转成es5,这应该算是我们最初使用babel的一个缘由,随着业务的开发 ...
- 使用git bash编译安装sysbench时遇到的坑
Preface When I was compiling the sysbench just now,I encountered some failures in the preced ...
- android自动化のadb常用命令(不定期更新)
1. adb devices 执行结果是adb为每一个设备输出以下状态信息:序列号(serialNumber) — 由adb创建的使用控制台端口号的用于唯一标识一个模拟器或手机设备的字符串,格式是 & ...
- (Python爬虫05)完善的爬虫学习大纲
- 【xmlHttp_Class 远程访问类】使用说明
类名:xmlHttp_Class 说明:远程获取外部网站数据信息或执行一个外部网站程序 目录: 类型 名称 参数 返回 说明 属性 [必需] [xmlHttp].url = [urlString] - ...
- flex布局笔记
flex布局: 容器: 容器主轴方向: 项目的主轴对齐方式: space-between:两端对齐,项目之间的间隔都相等. space-around:每个项目两侧的间隔相等.所以,项目之间的间隔比项目 ...
- JAVA基础学习之路(一)基本概念及运算符
JAVA基础概念: PATH: path属于操作系统的属性,是系统用来搜寻可执行文件的路径 CALSSPATH: java程序解释类文件时加载文件的路径 注释: 单行注释 // 多行注释 /*... ...
- centos端口管理
centos 6.5 ###############配置filter表防火墙############### #清除预设表filter中的所有规则链的规则iptables -F #清除预设表filter ...
- URAL 1297 Palindrome(Manacher)
The “U.S. Robots” HQ has just received a rather alarming anonymous letter. It states that the agent ...