zoukankan      html  css  js  c++  java
  • 卡特兰数

     转至http://lanqi.org/skills/10939/

    原理:

      令h(0)=1,h(1)=1,catalan 数满足递归式:

            (其中n>=2)

      另类递推公式:

          

      该递推关系的解为:

            (n=1,2,3,...)

      卡特兰数的应用实质上都是递归等式的应用

      前几项为:1, 1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700, 1767263190, 6564120420, 24466267020, 91482563640, 343059613650, 1289904147324, 4861946401452, ...

    问题一    进出栈

    栈是一种先进后出(FILO,First In Last Out)的数据结构.如图1,1,2,3,4顺序进栈,那么一种可能的进出栈顺序是

    1In→2In→2Out→3In→4In→4Out→3Out→1Out,

    于是出栈序列为1,3,4,2.

    图1    栈是先进后出的数据结构

    那么一个足够大的栈的进栈序列为1,2,3,⋯,n时有多少个不同的出栈序列?

        首先,每一种进出栈的顺序都与出栈序列一一对应.也就是说,如果我们用+1表示进栈,−1表示出栈,那么题中示例中的出栈序列1,3,4,2与进出栈顺序

    +1,+1,−1,+1,+1,−1,−1,−1,

    是对应的.

    那么对n个数的序列,总的进出栈顺序是给2n个1前面挑n个添加+号,其他的添加−号,共C2nn种吗?

    答案是否定的,这是因为出栈的前提是有进栈动作,于是要求每个排列中的前若干项和均不为负数,也就是说排列

    1,−1,−1,1,1,−1,−1,1

    是无效的.

    那么无效的排列到底有多少呢?

    考虑M是所有无效的排列构成的集合,考虑其中第一次发现排列无效的时候,也就是第一次发现其前若干项和为−1的时候,此时我们将包含使得前若干项和为−1的这一项开始的之前的所有项全都取相反数,那么就会得到一个新的排列,这个排列包含n+1个+1,以及n−1个−1,设所有这样的排列构成集合N.

    显然,这个M→N的映射是一一映射(N中的每一个排列从第一项往后累积求和的时候必然会出现和为+1的情形,此时将排列中使得和为+1的这一项连同之前的所有项全部取相反数,那么就会得到M中的一个排列).

    因此无效的排列共有C2nn−1个.

    综上,所有不同的出栈序列总数为C2nn−C2nn−1,即1n+1C2nn.

    进出栈问题的一个简单变形就是二叉树问题:

    n+1个叶子的满二叉树的个数,如图8.

    QQ20151105-6

    图8    n+1个叶子的满二叉树的个数问题

    事实上,向左记为+1,向右记为−1,按照向左优先的原则,从根节点开始遍历.例如第一个图记为

    +1,+1,+1,−1,−1,−1,

    于是由卡特兰数的含义可得满二叉树的个数为Cn.

     问题二    电影购票

    电影票每张50元,如果有m+n个人排队买票,其中m个人各持有50元面值的钞票1张,另外n个人各持有100元面值的钞票1张,而票房没有预备找零.有多少种方法可以将这m+n个人排成一列,顺序购票,使得无需因为等待找零而耽误时间?

        我们给进出栈问题一个几何模型:

    如图2,在n×n的方格地图中,从一个角到另一个角(成对角线),不跨越对角线的路径数.

    QQ20151105-0

    图2   方格地图中的受限路径数

    只要将向右记为+1,向上记为−1,就转化成了问题一.

    利用这个模型,我们解决这个卡特兰问题的变形问题,并顺便给进出栈问题的解法一个几何解释.

    如图3,在一个m×n的网格中,从左下角的原点O(0,0)出发,每次向右(表示接待的观众持有50元的钞票)或向上(表示接待的观众持有100元的钞票)移动,最终到达P(m,n).我们需要找到在直线y=x下方(包括边界)的路径条数.

    QQ20151105-7

    图3    矩形地图中的受限路径数

    从反面考虑问题.设M为穿过直线y=x(表示会经过直线上方的点)的从O→P的路径组成的集合,如图4.

    QQ20151105-8

    图4    犯规的路径

    如图5,利用对称可以将M中第一次犯规时的路径对称,然后再将剩下的部分接在对称后的路径上,由于此时将一次向上移动修改为了向右移动,因此终点由P变成了P′,此时就建立了与O到P′的路径的一个一一映射.

    QQ20151105-9

    图5    利用对称建立对应关系

    因此

    card(M)=card(N)=Cm+nn−1,

    于是所求的排列数为

    Cm+nn−Cm+nn−1.

    特别的,当m=n时有

    Cm+nn−Cm+nn−1=C2nn−C2nn−1=1n+1C2nn,

    即卡特兰数.

     问题三    圆内连弦

    如图6,圆周上有2n个点,以这些点为端点连互不相交的n条弦,求不同的连法总数.

    图8 圆内连弦不交问题

    图6   圆内连弦问题

        为了解决这个问题,我们重新解释卡特兰数的推导方式.先解决下面的辅助问题:

    圆周上有2n+1个点,其中n+1个点上标“+1”,n个点上标“−1”,如果可以找到某个标有“+1”的点作为起点,当顺时针沿圆周前进时将所遇到的点(包括起点)上标的数相加得到的和始终为正数,就称这种标记法是好标记法.求好标记法的总数(注意考虑圆排列).

    辅助问题的解    对于任何一种标记法,我们将顺时针相邻的“+1”“−1”(指顺时针前进时先遇到“+1”后遇到“−1”)同时抹去,可以证明抹去的前后对标记法的好坏没有影响.不停的重复这一过程,则最后只剩一个标有“+1”的点,显然此时标记法为好的.因此所有的标记法都是好标记法,显然其数目为

    12n+1C2n+1n=1n+1C2nn.

    问题的解    通过对辅助问题的进一步探索可知,每一种将圆周上2n+1个点标记为n+1个+1点,和n个−1点的方法唯一确定一个顺时针前进的方案(即起点).我们将这个起点删去,剩下的2n个点在顺时针方向上一定为“+1”“−1”“+1”“−1”,…,此时将顺时针相邻的这些“+1”“−1”点用弦连接起来,就得到互不相交的n条弦.这样我们就建立了从好标记法到弦的连法的单射.

    反过来,如果我们有了一种弦的连法,就可以从某条弦的端点出发顺时针前进,对每条弦的两个端点都是先遇到的端点标上“+1”,后遇到的端点标上“−1”,然后在最后回到出发点时添上一个标有“+1”的点.这样我们就建立了从弦的连法到好标记法的单射.

    综上,所求的不同连法数为1n+1C2nn.

    问题四   凸多边形的剖分(卡特兰问题)

    求凸n+2边形用其n−1条对角线分割为互不重叠的三角形的分法总数.

    QQ20151105-11

    图7    凸n+2边形的所有剖分方法总数

        先介绍两个关于卡特兰数Cn的小引理,将问题一中的+1和−1分别看成左括号和右括号,我们得到

    引理一    由n对括号形成的合法括号表达式的个数为Cn.

    比如n=3时,所有合法的括号表达式有

    ((())),(())(),()(()),()()(),(()()),

    5个.

    考虑n+1个数相乘,不同的相乘顺序的数目.我们可以给出每一个合法的括号表达式和一种可能的相乘顺序的对应方式.如n=3时,先取4个数a,b,c,d,然后在第一个数下设一个指针,将一个左括号看成是指针右移一格,而将右括号看成是将指针当前指向的数与其左侧的一个数作乘积,并删除左侧的那个数,那么当执行完括号表达式,就得到了一种可能的相乘顺序,如图8.

    QQ20151106-2

    图8  合法括号表达式与可能的相乘顺序的对应

    这样我们就从引理一出发得到了

    引理二    n+1个数连乘,不同的乘法顺序数为Cn.

        这样也是RPN模式的计算机的工作模式,可以无需括号完成计算,从而节省按键的次数.这种计算器在财务计算中大量使用,如图.

    QQ20151106-3

    图9 Mac OS X下计算器的PRN模式

    接下来解决卡特兰问题,用1,2,3,⋯,n+2标记凸n+2边形的边,从标记为1的边的起点(按逆时针方向)开始按未标记的对角线均为向外标记方向,如图10.

    QQ20151105-5

    图10  分别标记边和对角线

    进而,逆时针读图,将出的箭头读为左括号,进的箭头读为右括号,就得到了剖分方式与连乘顺序的对应.图10中的两个图对应的连乘顺序表达式分别为

    1((2(34))5)6,(1(23))(45)6,

    抛开6不计,每个连乘顺序表达式实际上就是规定了n+1个数连乘时,不同的乘法顺序,根据引理一,得到剖分方式的总数为Cn.

    卡特兰数的性质

    卡特兰数有一些优美的性质,如

    通项公式一    

    通项公式二    

    递推公式一    

    递推公式二   

    增长速度    

    由卡特兰问题以及其各种变形很容易推导卡特兰数的递推公式.相应的,我们也可以利用递推公式二来发现和证明某些卡特兰问题的变形,比如:

    探索用n个长方形去填充一个高度为n的阶梯图形的方法数,如图11.

    QQ20151105-10

    图11   阶梯图形的填充

        把包含左上角的矩形去掉,就很容易由递推公式二推得所有填充方法数就是卡特兰数Cn了.

  • 相关阅读:
    echarts labelLayout
    可视化学习及实战记录
    VS2008提示无法打开包括文件:“afxcontrolbars.h”解决办法
    原码、补码和反码
    第一篇
    vc2008编译就提示找不到msvcr90d.dll
    Vue H5 与 APP 交互 (IOS为例)
    VS Code中小程序与Vue常用插件合集(前端合集)
    如何在Element 使用正则表达式校验
    分享CSS公共类库(能在项目快捷使用CSS类)
  • 原文地址:https://www.cnblogs.com/yuanlinghao/p/11234205.html
Copyright © 2011-2022 走看看