首页 > 其他分享 >卡特兰数

卡特兰数

时间:2024-04-03 20:23:35浏览次数:38  
标签:ans 序列 2n coin 卡特兰 MOD

卡特兰数

一、计算公式

\(C_1 = 1\), \(C_n = C_{n - 1} \frac{4n - 2} {n + 1} = C_{2n}^{n} - C_{2n}^{n + 1} = \frac {C_{2n}^n} {n + 1}\)

二、应用场景

场景1

n 个元素进栈序列为:1,2,3,4,...,n,则有多少种出栈序列?

将进栈表示 +1,出栈表示为-1。要想是合法序列,则 +1的数量要大于等于-1。

场景2

n 对括号,则有多少种 括号匹配 的括号序列?

场景3

给定 n 个0 和 n个1,它们将按照某种顺序排成长度为2n的序列,求它们能排列成的所有序列中,能够满足任意前缀序列中0的个数都不少于 1 的个数的序列有多少个。答案对 \(10^9+7\)​取模

情景4

8 个高矮不同的人需要排成两队,每队 4 个人。其中,每排都是从低到高排列,且第二排的第 i 个人比第一排中第 i 个人高,则有多少种排队方式。

情景5

电影票一张 50 coin,且售票厅没有 coin。m 个人各自持有 50 coin,n 个人各自持有 100 coin!

则有多少种排队方式,可以让每个人都买到电影票。

注:必须先让持有50 coin的人买票,然后才能有钱找给持有100 coin的人

如果考率不同的人顺序的话,答案为\((C_{m + n}^{m} - C_{m + n}^{m + 1}) * m! * n!\)

三、证明

引用链接:https://www.acwing.com/solution/content/8907/
感谢番茄酱
image

四、求卡特兰数

MOD = 10 ** 9 + 7
def exgcd(a,b):
    if b == 0:
        return 1,0,a
    x,y,gcd = exgcd(b,a % b)
    x,y = y,(x - (a // b) * y)
    return x,y,gcd
def inv(x):
    o,_,_ = exgcd(x,MOD)
    return o % MOD
n = int(input())
ans = 1

for i in range(2,n + 1):
    ans = (ans * (4 * i - 2) * inv(i + 1)) % MOD
print(ans % MOD)

标签:ans,序列,2n,coin,卡特兰,MOD
From: https://www.cnblogs.com/gebeng/p/18113443

相关文章

  • 卡特兰数、Prüfer 序列、BSGS
    1卡特兰数1.1概述卡特兰数的前几项是$1,1,2,5,14,42,132,429,1430,4862\cdots$。卡特兰数在组合数学中有着许多应用。下面给出一个经典例子:在网格中向右或向上走,从$(0,0)$走到$(n,n)$,并且不能越过对角线的路径条数。该问题的结果就是卡特兰数,记为$H_n$。1.2通项公......
  • 卡特兰数
    为区别于组合数,用\(Cat(n)\)代表卡特兰数的第n项是一种数列,其通项公式的一种形式为:\(Cat_n=\frac{1}{n+1}\timesC_{2n}^{n}(n=0,1,2...)\)前几项数值为\(1,1,2,5,14,42,132,429\)增长幅度为\(O(4^n)\)递归定义式1\(Cat_n=\sum_{i=0}^{n-1}Cat_i\timesCat_{n-i-1}\)理解:......
  • 卡特兰数小记
    引入\(n\)个节点的二叉树个数。长度为\(2n\)的合法括号序列数量。不加说明的给出结论:上面两个问题的答案均为卡特兰数列\(H\)的第\(n\)项,\(H_n\)。暴力DP理解第一个问题设DP状态\(f(i)\)为\(i\)个节点的二叉树个数。求\(f(i)\)时,枚举左儿子节点数量\(j......
  • 关于卡特兰数
    不那么有意思的定义卡特兰数\(\big(Catalan\big)\)用\(H\)来表示,有形式如:\(H_n=\dfrac{\binom{2n}n}{n+1}(n\geq2)\)很好,你已经知道定义了。老师说:它是栈出栈入栈的\(方案数\)\(???\)放到一个递推式就有了:\(H_n=\begin{cases}H_{n-1}+H_{n-2}&\text{if}......
  • CF-1831-E-卡特兰数+异或哈希+差分
    1831-E题目大意给定一个整数\(n\),和\(k\)个区间,区间端点范围在\([1,n]\)内。如果有一个长为\(n\)合法的括号序列,且它的这\(k\)个区间\([l,r]\)中的子括号序列也是合法的,那么称这个括号序列是“好的”。请你求出有多少个长度为\(n\)的“好的”括号序列,答案对\(998244353\)取模......
  • 卡特兰数&斯特林数
    卡特兰数引入不妨从找规律开始。下标从\(0\)开始,卡特兰数的前几项为:1,1,2,5,14,42,132,429,1430,4862,16796,58786,208012,742900,2674440,9694845,35357670,129644790…那么通过认真的瞪眼观察,会发现它们满足递推关系。关于卡特兰数是一个很常见的数列。它并没有一个足够......
  • 火车进栈 (卡特兰数+位压高精)
    火车进栈(卡特兰数+位压高精)[题目](130.火车进出栈问题-AcWing题库)思路:车厢进出栈视为\(01\)序列,则每种\(01\)序列对应一种出栈顺序,答案即为:\({\Large\frac{1}{n+1}C_{2n}^{n}}\)数据范围:\(1{\Large\le}n{\Large\le}60000\)(数据开到\(2n\),因为这个卡了一小时qwq......
  • 卡特兰数专题(Catalan)
    卡特兰数专题(\(Catalan\))一、什么是卡特兰数?明安图数,又称卡塔兰数,英文名\(Catalan\)\(number\),是组合数学中一个常出现于各种计数问题中的数列。以中国蒙古族数学家明安图\((1692-1763)\)和比利时的数学家欧仁·查理·卡塔兰\((1814–1894)\)的名字来命名,其前几项为(从第零项开......
  • 卡特兰数专题(Catalan)
    卡特兰数专题(\(Catalan\))一、什么是卡特兰数?明安图数,又称卡塔兰数,英文名\(Catalan\)\(number\),是组合数学中一个常出现于各种计数问题中的数列。以中国蒙古族数学家明安图\((1692-1763)\)和比利时的数学家欧仁·查理·卡塔兰\((1814–1894)\)的名字来命名,其前几项为(从第零项......
  • 【学习笔记】卡特兰数
    卡特兰数定义:卡特兰数的计算公式涉及组合计数,它是很多组合问题的数学模型,是一个很常见的数列。\(\bf{\underline{卡特兰数(Catalan)}}\)是一个数列,它的一种定义是:\[C_n=\frac{1}{n+1}\binom{2n}{n},n=0,1,2,...\]卡特兰数有三个计算公式:公式1:\[C_n=\frac{1}{n+1}\binom{2n}......