01卡特兰数

卡特兰数跟排列组合很有关系,所以在看此文章前请掌握:

  • 加法原理
  • 乘法原理
  • A(m,n)计算公式及其原理
  • C(m,n)计算公式及其原理

前言

今天您将会学习到基本的卡特兰数及其应用。


一、卡特兰数是什么?

        卡特兰数(Catalan number)是组合数学中一种常出现于各种计数问题中的数列。其前几项为:1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700, 1767263190, 6564120420, 24466267020, 91482563640, 343059613650, 1289904147324, 4861946401452, ...        

二、卡特兰数如何计算

设h(n)为catalan数的第n项,令h(0)=1,h(1)=1,catalan数满足递推式:

h(n)= h(0)*h(n-1)+h(1)*h(n-2) + ... + h(n-1)*h(0) (n≥2)

例如:h(2)=h(0)*h(1)+h(1)*h(0)=1*1+1*1=2

        h(3)=h(0)*h(2)+h(1)*h(1)+h(2)*h(0)=1*2+1*1+2*1=5

另类递推式:

h(n)=h(n-1)*(4*n-2)/(n+1)h(n+1)=h(n) * (4*n + 2) / (n + 2)

递推关系的解为:

h(n)=C(2n,n)/(n+1) (n=0,1,2,...)

递推关系的另类解为:

h(n)=C(2n,n) - C(2n,n-1) (n=0,1,2,...)

三、卡特兰的实际应用

1.思路分析

您可以先看这一题。

现在我们来思考这道题:

首先,我们设 f(n)=序列个数为n的出栈序列种数。(我们假定,最后出栈的元素为k,显然,k取不同值时的情况是相互独立的,也就是求出每种k最后出栈的情况数后可用加法原理,由于k最后出栈,因此,在k入栈之前,比k小的值均出栈,此处情况有f(k-1)种,而之后比k大的值入栈,且都在k之前出栈,因此有f(n-k)种方式,由于比k小和比k大的值入栈出栈情况是相互独立的,此处可用乘法原则,f(n-k)*f(k-1)种,求和便是Catalan递归式。)

首次出空之前第一个出栈的序数k将1~n的序列分成两个序列,其中一个是1~k-1,序列个数为k-1,另外一个是k+1~n,序列个数是n-k。

此时,我们若把k视为确定一个序数,那么根据乘法原理,f(n)的问题就等价于——序列个数为k-1的出栈序列种数乘以序列个数为n - k的出栈序列种数,即选择k这个序数的 f(n) =f(k-1) × f(n-k)。而k可以选1到n,所以再根据加法原理,将k取不同值的序列种数相加,得到的总序列种数为:f(n) = f(0)f(n-1) + f(1)f(n-2) + …… + f(n-1)f(0)。

2.我的打表代码
#include<bits/stdc++.h>
using namespace std;
long long a[18]={1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700};
int main(){int x;cin>>x;cout<<a[x-1]<<endl;return 0;
}

四、AI说的话

1.AI对卡特兰数的评价

卡特兰数是一种非常重要的组合数学概念,它在许多领域都有广泛应用。下面是对卡特兰数的一些评价:

1. 卡特兰数可以表示组合问题和路径计数问题。

2. 卡特兰数的计算方法简单明了,可通过递推公式或生成函数求解。

3. 卡特兰数的性质丰富,涉及到二叉树、括号序列、山峰序列等多种组合结构。

4. 卡特兰数常被用于解决实际问题,如括号匹配、高维几何计算等。

5. 卡特兰数还具有一些意想不到的应用,如计算有限自动机、判断合法的棋盘布局等。

总之,卡特兰数作为组合数学中的重要概念,不仅具有理论意义,更有着实际应用价值。

2.AI解释卡特兰数的应用

卡特兰数是一类非常重要的数列,因为它们可以用于解决许多实际应用问题。以下是卡特兰数的一些应用:

  1. 括号序列:一个括号序列是由左右括号组成的字符串,例如 (()())。卡特兰数可以用于计算长度为n的括号序列的数量,以及其中合法的括号序列的数量。

  2. 凸多边形三角剖分:在凸多边形中,任何三角形的划分都可以由其对角线进行。卡特兰数可以用于计算划分凸多边形所需的对角线数量。

  3. 二叉树:卡特兰数也可以用于计算由n个节点构成的二叉树的数量。这里,每个节点不仅包含一个值,而且还包含指向其左子节点和右子节点的指针。

  4. 杨表:卡特兰数也可以用于计算n个数的杨表的数量,其中杨表是一种将n个数排列成不降序列的方案。

  5. 格路线:在一个n×n的网格上,从左下角到右上角的路径必须从每个格子的下方或右方穿过。卡特兰数可以用于计算这样的路径的数量。

  6. 栈的操作序列:假设我们有一个空栈,我们可以将n个数字插入该栈。卡特兰数可以用于计算所有n个数字的操作序列的数量,其中每个操作可以是“压入”或“弹出”。

  7. 电力分配:假设我们有n台发电机和n个城市,每台发电机都可以向多个城市提供电力。卡特兰数可以用于计算所有可能的电力分配方案。

总之,卡特兰数在组合数学中起着非常重要的作用,它们的应用广泛,不仅仅限于上述问题。

3.AI生成的卡特兰数C++代码

以下是使用C++语言生成卡特兰数的示例代码:

#include <iostream>
using namespace std;unsigned long int catalanDP(unsigned int n)
{// Table to store precomputed values of catalan numbersunsigned long int catalan[n + 1];// Initialize first two values in tablecatalan[0] = catalan[1] = 1;// Fill entries in catalan[] using DPfor (int i = 2; i <= n; i++){catalan[i] = 0;for (int j = 0; j < i; j++)catalan[i] += catalan[j] * catalan[i - j - 1];}// Return last entryreturn catalan[n];
}int main()
{for (int i = 0; i < 10; i++)cout << catalanDP(i) << " ";return 0;
}

此示例代码使用动态规划方法来计算卡特兰数,并使用循环生成前10个卡特兰数。


总结

以上就是今天要讲的内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/74975.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RabbitMq消息模型-队列消息

队列消息分为2种&#xff1a; 基本模型&#xff08;SimpleQueue&#xff09;、工作模型&#xff08;WorkQueue&#xff09; 队列消息特点&#xff1a; 消息不会丢失 并且 有先进先出的顺序。消息接收是有顺序的&#xff0c;不是随机的&#xff0c;仅有一个消费者能拿到数据&…

java实现课程表 II

题目&#xff1a; 现在你总共有 numCourses 门课需要选&#xff0c;记为 0 到 numCourses - 1。给你一个数组 prerequisites &#xff0c;其中 prerequisites[i] [ai, bi] &#xff0c;表示在选修课程 ai 前 必须 先选修 bi 。 例如&#xff0c;想要学习课程 0 &#xff0c;…

如何建设一个安全运营中心(SOC)?

然信息安全管理问题主要是个从上而下的问题&#xff0c;不能指望通过某一种工具来解决&#xff0c;但良好的安全技术基础架构能有效的推动和保障信息安全管理。随着国内行业IT应用度和信息安全管理水平的不断提高&#xff0c;企业对于安全管理的配套设施如安全运营中心&#xf…

Hexo小结

Hexo小结 前段时间自己搭建了博客&#xff0c;后来维护太麻烦&#xff0c;放弃了&#xff0c;但还是做个基本使用的小结。 Hexo小结 Hexo 是一个基于 Node.js 的快速、简单和强大的博客框架。以下是一些常用的 Hexo 命令&#xff1a; hexo init [folder]&#xff1a;在指定文…

Spring boot环境搭建

使用IDE工具&#xff1a;IntelliJ IDEA 目录 一、安装JAVA 二、安装maven&#xff08;Java项目管理工具&#xff09; 三、安装IDE 四、在IDE中配置spring boot项目环境 1、配置jdk 2、配置maven 3、安装创建spring boot项目插件&#xff1a;Spring Assistant 4、安装简…

Linux 指令心法(五)`mv` 移动或重命名文件和目录

文章目录 命令的概述和用途命令的用法命令行选项和参数的详细说明命令的示例命令的注意事项或提示 命令的概述和用途 mv 是 “move” 的缩写&#xff0c;它是一个 Linux 和 Unix 系统中的命令&#xff0c;用于移动或重命名文件和目录。使用 mv 命令&#xff0c;用户可以将文件…

LTGNet-超分辨率OCTA图像分割

目录 一、摘要 二、引言 三、方法 A. Reference-based框架 B. Learnable Texture Generator 四、实验 五、总结 一、摘要 研究背景&#xff1a;光学相干断层血管成像(OCTA)是一种新的视网膜微血管成像方式&#xff0c;已广泛应用于临床。 高分辨率OCT血管造影对于定性和…

LeetCode 面试题 04.02. 最小高度树

文章目录 一、题目二、C# 题解 一、题目 给定一个有序整数数组&#xff0c;元素各不相同且按升序排列&#xff0c;编写一个算法&#xff0c;创建一棵高度最小的二叉搜索树。 点击此处跳转题目。 示例: 给定有序数组: [-10,-3,0,5,9], 一个可能的答案是&#xff1a;[0,-3,9,-10…

台式万用表几位的概念以及NPLC的功能作用

数字万用表测量电流和电压的基本原理是通过检测传感器的电阻&#xff0c;电容&#xff0c;或电感等特性&#xff0c;将电流或电压转化为可以测量的电信号&#xff0c;然后这个电信号被转化为数字信号进行处理和显示。具体的&#xff0c;当测量电压时&#xff0c;万用表的输入端…

JavaScript中的事件捕获(event capturing)和事件冒泡(event bubbling)

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 事件捕获和事件冒泡⭐ 事件捕获&#xff08;Event Capturing&#xff09;示例&#xff1a; ⭐ 事件冒泡&#xff08;Event Bubbling&#xff09;示例&#xff1a; ⭐ 应用场景⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开…

LeetCode 面试题 03.04. 化栈为队

文章目录 一、题目二、C# 题解 一、题目 实现一个MyQueue类&#xff0c;该类用两个栈来实现一个队列。 点击此处跳转题目。 示例&#xff1a; MyQueue queue new MyQueue(); queue.push(1); queue.push(2); queue.peek(); // 返回 1 queue.pop(); // 返回 1 queue.empty(); /…

k8s中的有状态,无状态,pv、pvc等

数据库是一个典型的有状态服务&#xff0c;他的部署和无状态服务是不一样的。 PostgresSQL----基于Kubernetes部署PostgresSQL-CSDN博客 一、创建SC、PV和PVC存储对象 二、部署PostgresSQL Volume Kubernetes 中文指南——云原生应用架构实战手册 有状态应用&#xff1a; …

基于TensorFlow 2.3.0 的手势识别系统设计

一、开发环境 Windows 10PyCharm 2021.3.2Python 3.7TensorFlow 2.3.0 二、制作数据集&#xff0c;作者使用了10个类别的手势数集据 三、开始训练模型&#xff0c;作者使用自己开发的软件进行训练模型&#xff0c;方便快捷。软件介绍及下载地址&#xff1a; 手把手教你使用T…

单片机C语言实例:14、音频输出

一、喇叭发声原理 程序实例1&#xff1a; #include<reg52.h> //包含头文件&#xff0c;一般情况不需要改动&#xff0c;头文件包含特殊功能寄存器的定义sbit SPK P1^2; //定义喇叭端口 /*------------------------------------------------函数声明 --------------…

Elasticsearch脑裂

文章目录 Elasticsearch脑裂 Elasticsearch脑裂 Elasticsearch脑裂是指由于网络分区或节点间通信故障导致集群中的节点无法互相正常通信&#xff0c;从而导致数据不一致的情况。这可能会导致集群中的多个节点同时自认为是主节点&#xff08;master&#xff09;&#xff0c;并开…

【实战】React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(总结展望篇)

文章目录 一、项目起航&#xff1a;项目初始化与配置二、React 与 Hook 应用&#xff1a;实现项目列表三、TS 应用&#xff1a;JS神助攻 - 强类型四、JWT、用户认证与异步请求五、CSS 其实很简单 - 用 CSS-in-JS 添加样式六、用户体验优化 - 加载中和错误状态处理七、Hook&…

ASP.net web应用 GridView控件常用方法

GridView 控件是 ASP.NET Web Forms 中常用的数据展示控件之一。它提供了一个网格形式的表格&#xff0c;用于显示和编辑数据。GridView 控件对于包含大量数据、需要进行分页、排序和筛选的情况非常有用。 GridView 控件的主要特性包括&#xff1a; 数据绑定&#xff1a;GridV…

linux Nginx+Tomcat负载均衡、动静分离

linux NginxTomcat负载均衡、动静分离 1、Tomcat的基本介绍1.1Tomcat是什么&#xff1f;1.2Tomcat的构成组件1.3Tomcat的核心功能1.4Tomcat请求过程 2、Tomcat部署2.1安装tomcat2.2优化tomcat启动速度2.4主要目录说明 3、Tomcat 虚拟主机配置3.1创建fsj和mws项目目录和文件3.2修…

【TypeScript】TypeScript的介绍、安装和配置

TypeScript简介 TypeScript是JavaScript的超集。它对JS进行了扩展&#xff0c;向JS中引入了类型的概念&#xff0c;并添加了许多新的特性。TS代码需要通过编译器编译为JS&#xff0c;然后再交由JS解析器执行。TS完全兼容JS&#xff0c;换言之&#xff0c;任何的JS代码都可以直…

Unity(三) Shader着色器初探

学习3D开发技术的时候无可避免的要接触到Shader&#xff0c;那么Shader是个什么概念呢&#xff1f;其实对于开发同事来说还是比较难理解的&#xff0c;一般来说Shader是服务于图形渲染的一类技术&#xff0c;开发人员可以通过其shader语言来自定义显卡渲染页面的算法&#xff0…