卡特兰数问题

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

相关文章

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原