卡特兰数问题

2023-11-07 01:59
文章标签 问题 卡特兰

本文主要是介绍卡特兰数问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

链接

卡特兰数 - http://lanqi.org/skills/10939/

数值

C0 = 1,         
C1 = 1,         C2 = 2,          C3 = 5,          C4 = 14,          C5 = 42,
C6 = 132,       C7 = 429,        C8 = 1430,       C9 = 4862,        C10 = 16796,
C11 = 58786,    C12 = 208012,    C13 = 742900,    C14 = 2674440,    C15 = 9694845,
C16 = 35357670, C17 = 129644790, C18 = 477638700, C19 = 1767263190, C20 = 6564120420, ...

公式

  • 通项公式一 C n = 1 n + 1 C 2 n n = C 2 n n − C 2 n n − 1 = C 2 n n − C 2 n n + 1 C_n = \frac{1}{n+1}C_{2n}^n=C_{2n}^n-C_{2n}^{n-1}=C_{2n}^n-C_{2n}^{n+1} Cn=n+11C2nn=C2nnC2nn1=C2nnC2nn+1

  • 通项公式二: C n = 1 n + 1 ∑ i = 0 n ( C n i ) 2 C_n = \frac{1}{n+1}\sum_{i=0}^n\left(C_{n}^i\right)^2 Cn=n+11i=0n(Cni)2

  • 递推公式一: C n + 1 = 2 ( 2 n + 1 ) n + 2 C n C_{n+1} = \frac{2(2n+1)}{n+2}C_n Cn+1=n+22(2n+1)Cn

  • 递推公式二 C n + 1 = C 0 × C n + C 1 × C n − 1 + … + C n − 1 × C 1 + C n × C 0 C_{n+1} = C_0\times C_n+C_1\times C_{n-1}+…+C_{n-1}\times C_1+C_n\times C_0 Cn+1=C0×Cn+C1×Cn1++Cn1×C1+Cn×C0

  • 增长速度: Δ C n ∼ 4 n n 3 2 × π \Delta C_n \sim \frac{4^n}{n^{\frac{3}{2}}\times\sqrt{\pi}} ΔCnn23×π 4n

通项公式一

  • 设由n+1个 -1 和 n-1个 +1 (或者:n+1个 +1 和 n-1个 -1 )组成长度为2n的序列A。所有的可能数量a1
    a 1 = ( 2 n ) ! ( n + 1 ) ! × ( n − 1 ) ! a_1=\frac{(2n)!}{(n+1)!\times(n-1)!} a1=(n+1)!×(n1)!(2n)!

  • 设由n个 +1 和 n个 -1 组成长度为2n的序列B。序列B若满足“前任意项的和不小于0”,则称该序列为合法序列,否则称非法序列

    • 所有非法的序列可能数量b1
      b 1 = a 1 = ( 2 n ) ! ( n + 1 ) ! × ( n − 1 ) ! b_1 = a_1=\frac{(2n)!}{(n+1)!\times(n-1)!} b1=a1=(n+1)!×(n1)!(2n)!
    • 所有合法的序列可能数量b2
      b 2 = ( 2 n ) ! n ! × n ! − b 1 = 1 n + 1 × ( 2 n ) ! n ! × n ! = 1 n + 1 × C ( 2 n , n ) b_2=\frac{(2n)!}{n!\times n!} - b_1 = \frac{1}{n+1} \times \frac{(2n)!}{n!\times n!} = \frac{1}{n+1} \times C(2n, n) b2=n!×n!(2n)!b1=n+11×n!×n!(2n)!=n+11×C(2n,n)
  • 为什么 b1 = a1

    • A序列和非法B序列,前若干项和第一次小于0的位置只能是1、3、5、……、2n-1
    • 根据第一次小于0位置对A序列、非法的B序列进行分类,都可以分为n类
    • 前若干项和第一次小于0时,此时的和一定等于 -1
    • 对于A序列,在2k+1位置第一次和小于0
      1 , … … , − 1 ⏟ k 个 ± 1 , − 1 , … … ⏟ n − k − 1 个 + 1 , n − k 个 − 1 \underbrace{1,……,-1}_{k个\pm1},-1,\underbrace{……}_{n-k-1个+1,n-k个-1} k±1 111nk1+1nk1
    • 对于非法B序列,在2k+1位置第一次和小于0
      1 , … … , − 1 ⏟ k 个 ± 1 , − 1 , … … ⏟ n − k 个 + 1 , n − k − 1 个 − 1 \underbrace{1,……,-1}_{k个\pm1},-1,\underbrace{……}_{n-k个+1,n-k-1个-1} k±1 111nk+1nk11
    • 结论:在2k+1位置第一次和小于0,对应的可能数量相等。因此b1 = a1 成立

递推公式二

  • 对于合法B序列,前若干项和第一次等于0的位置只能是 2,4,6,……,2n
  • 根据第一次等于0的位置对合法B序列进行分类,都可以分为n类
  • 分类后,每类由两个子问题构成;例如:在2k位置第一次和等于0
    1 , 1 , … … , − 1 ⏟ k − 1 个 ± 1 , − 1 ⏞ k 个 ± 1 , 1 , … … , − 1 ⏟ n − k 个 ± 1 \overbrace{1,\underbrace{1,……,-1}_{k-1个\pm1},-1}^{k个\pm1},\underbrace{1,……,-1}_{n-k个\pm1} 1k1±1 111 k±1nk±1 11
    对应的排列数:
    C k − 1 × C n − k C_{k-1} \times C_{n-k} Ck1×Cnk
    所以,总的排列数
    C n = C 0 × C n − 1 + C 1 × C n − 2 + C 2 × C n − 3 + … + C n − 1 × C 0 C_n = C_0\times C_{n-1}+C_1\times C_{n-2}+C_2\times C_{n-3}+…+C_{n-1}\times C_0 Cn=C0×Cn1+C1×Cn2+C2×Cn3++Cn1×C0

例题

  • 一个足够大的栈的进栈序列为1,2,3,…,n时有多少个不同的出栈序列?
    在这里插入图片描述

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

在这里插入图片描述


  • 有n个结点,问总共能构成几种不同的二叉树.
    如中序遍历,根结点第k个被访问到,则根结点的左子树有k-1个点、根结点的右子树有n-k个点。k的取值范围为1到n。【2015年腾讯实习生在线笔试题】

  • 一个凸的n边形,用直线连接它的两个顶点使之分成多个三角形,每条直线不能相交,问一共有多少种划分方案。在这里插入图片描述

  • 有n+1个叶子的满二叉树的个数?
    在这里插入图片描述
    向左记为+1,向右记为-1,按照向左优先的原则,从根节点开始遍历.例如第一个图记为+1,+1,+1,−1,−1,−1。【即符合卡特兰数的含义】

  • 在n*n的格子中,只在下三角行走,每次横或竖走一格,有多少中走法? 在这里插入图片描述
    向右相当于进栈,向左相当于出栈。(这个模型是进出栈问题的一个几何解释)

  • 由n对括号形成的合法括号表达式的个数。
    • 当n=3时,合法的表达式共有:((())),(())(),()(()),()()(),(()()),共5个。
    • 表达式和指针结合可以视作乘法操作指令。指针:指向操作数,初始时刻,指针指向第一个数;左括号:指针右移一格;右括号:将指针当前指向的数与其左侧的一个数作乘积,并删除左侧的那个数。
    • 如图所示,1,2,3,4相乘时取n=3,当执行完括号表达式,就得到了一种可能的相乘顺序.
      在这里插入图片描述

  • n+1个数连乘,不同的乘法顺序数。
    【提示:可以为每种可能的相乘顺序找到一个对应的合法的括号表达式。】

  • 将一个凸n+2边形区域分成三角形区域的方法数?
    【提示:任选一条边,使得该边对应不同的顶点】 在这里插入图片描述

  • n个长方形填充一个高度为n的阶梯状图形的方法个数?
    【提示:每一个区域必属于某个矩形,去掉顶点区域所在的矩形,则易由递推公式推得。】 在这里插入图片描述

  • 在一个2*n的格子中填入1到2n这些数值使得每个格子内的数值都比其右边和上边的所有数值都小的情况数。
    【提示:下,下,上,上,……】

  • n+m个人排队买票,并且满足,票价为50元,其中n个人各手持一张50元钞票,m个人各手持一张100元钞票,除此之外大家身上没有任何其他的钱币,并且初始时候售票窗口没有钱,问有多少种排队的情况数能够让大家都买到票。
    【提示:50,50,100,100,……】

这篇关于卡特兰数问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/360506

相关文章

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g