组合数学基础(卡特兰数)

文章探讨了卡特兰数在不同问题中的应用,如姐妹洗碗问题、进出栈问题和找零问题,这些问题本质上都是求解满足特定条件的方案数。通过递推法、分析法和公式法可以计算卡特兰数,它在括号匹配和非叶子结点的二叉树计数等问题中起到关键作用。
摘要由CSDN通过智能技术生成

卡特兰数公式:

或者

引例1、(姐妹洗碗问题)

思考过程:

横坐标表示姐姐洗完的碗的个数,纵坐标表示妹妹摞碗的个数,前提条件为妹妹摞碗的个数不能超过姐姐洗完的碗的个数,要求摞法的方案数实际上是求从坐标(0,0)到坐标(5,5)的所有满足条件的路径数。

引例2、(进出栈问题)

思考过程:

本质上和姐妹洗碗问题一致,都是求方案数,且前提条件都是同种前提条件,即出栈的个数不能超过栈中存在的数的个数。

引例3、(找零问题)

思考过程:

本质上和姐妹洗碗问题一致,都是求方案数,且前提条件都是同种前提条件,即当前持有10元纸币排队的人数不能超过当前持有5元纸币排队的人数。

卡特兰序列通式分析

分析3的初始条件为f(0)=1,f(1)=1.

例题1:

例题2:

思路:将左括号看成1,右括号看成-1,由于左右括号要匹配,即数量要求相同,且当前右括号数量不能超过当前已经放好的左括号数量,故满足卡特兰数,即求上述方案数只需要算长度为n+1个数需要添加的括号数对n,则方案数为卡特兰数第n项。

例题3:

求解n个非叶子结点的二叉树总共有多少种?

思路:将每个非叶子结点看成它的左右结点的结合,而n个非叶子结点的二叉树的总数即为根节点的所有结合方案数,即为例题2中括号的放置方案,即卡特兰数的第n项。

例题4:

思路:将该题转换为例题3二叉树,以a0边所在的区域作为根节点,每经过一条边,形成一个叶子结点或非叶子结点,如果线超出凸多边形,则形成的是叶子结点,否则形成的是非叶子结点,实际上只需要求出凸多边形的非叶子结点数n,则答案即为卡特兰数的第n项。

1.递推法:

2.分析法:

3.公式法:

例题5:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小白?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值