卡特兰数是一个特殊的数列,基于这个数列,可以找出很多有趣的问题,对于我们学计算机的而言,与这个数列打交道是不可避免了,举一个很经典的例子。我之前在栈的压入、弹出序列这篇文章中讲到过这个给定入栈序列,判断是否是合法的出栈序列。
与该问题类似的问题有很多,如果我们把问题进一步深入,我们去研究给定n个字符的入栈合法的出栈序列的种数是多少,这个时候,卡特兰数就会随之浮现出来。事实上我们耐心去思考,就能得到卡特兰数的递推公式,但是我们这里直接给结论。
使用场景
给定n个元素入栈,我们一共可以得到的合法出栈序列的个数就是卡特兰数第n项。,除此之外,这个神奇的数列还是以下诸多问题的解。
- 10个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问有多少种排列方式?
- 圆周上有标号为1,2,3,4,……,2n的共计2n个点,这2n个点配对可连成n条弦,且这些弦两