今天做acm题时碰到了卡特兰数,于是就上百度查了卡特兰数的解释,其中有这么一段:
其中提到首次出空之前第一个出栈的序数k,k把序列分成了1~k-1和k+1~n两个部分,把k作为序数时f(n)=f(k-1)*f(n-k),初看还比较有理,但是仔细一想,这个k之前的k-1个数都已经入栈,出栈序列只有一种,绝对不可能能是f(k-1)种,而且根据这个解释,序列的第一个数就应该是k,那么当k为4时,f(n)=f(3)*f(0)=5,但是根据图中程序结果4开始的序列只有一个.
各种搜索百度都只能找到公式而没有具体说明,我决定自己想办法解释,苦思冥想时突然灵光一现,把出栈序列分成两部分的不是第一个出栈的数,而是最后一个出栈的数,即所得序列的最后一个数,比对图中的程序结果,当k=1时有5个,k=2时有2个,k=3时有2个,k=4时有5个,正好符合公式.
怎么解释这个k呢,因为这个k是最后出栈的,因此当k入栈时1~k-1已经全部出栈了,也就是前k-1个数有f(k-1)种序列,而当k出栈时k+1~n已经全部出栈了,也就是后n-k个数有f(n-k)种序列,根据乘法原理,当最后一个数为k时,f(n)=f(k-1)*f(n-k),再根据加法原理,k=1,2,...n,即为f(n)=h(n)= C(2n,n)/(n+1)= c(2n,n)-c(2n,n+1)(n=0,1,2,……)。
想到这里,递推公式的由来我终于想明白了,至于百度百科对卡特兰数的其他说明,暂时没看出问题,特意写一篇博客,帮助没看懂百科解释的同学.