卡特兰数
大神解释:https://blog.csdn.net/akenseren/article/details/82149145 权侵删
原题
有一个容量足够大的栈,n个元素以一定的顺序入栈,出栈顺序有多少种?
比如,AB两个元素,入栈顺序为AB,出栈情况有两种:
(1)入A,出A,入B,出B,出栈顺序为AB;
(2)入A,入B,出B,出A,出栈顺序为BA。
因此,2个元素时,结果为2。
分析:设f(n)为“n个元素以一定的顺序入栈,出栈顺序的种类数”。显然f(1)=1,f(2)=2。我们现在来分析一般情况。一般情况下,我们可以按照“第一个入栈的元素,在出栈序列中的位置”作为分类手段。
举个例子,我们假设入栈元素为A,B,C,D。我们按照“A在出栈序列中的位置”分类讨论:
(1)当A第一个出栈时,A先进,然后马上出栈。这种情况下,共有“BCD出栈顺序的种类数”种方案。也就是f(n-1)。
(2)当A第二个出栈时,A先进,B再进,之后B需要马上出来(这样才能确保A排第二)。此时共有f(n-2)种方案。
(3)当A第三个出栈时,A先进,之后只要确保排在A后面两个的元素比A先出即可。此时共有f(2)*f(n-3)种方案。f(2)是指“BC入栈出栈顺序的种类数”,f(n-3)是指”D入栈出栈的种类数”。
……
分析到这里,规律就很显然了。
<