洛谷Oj-栈-卡特兰数

来源:互联网 发布:游戏界面编程 编辑:程序博客网 时间:2024/06/07 06:09

问题描述:
栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表。
栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈)。
栈的重要性不言自明,任何一门数据结构的课程都会介绍栈。宁宁同学在复习栈的基本概念时,想到了一个书上没有讲过的问题,而他自己无法给出答案,所以需要你的帮忙。

(原始状态如上图所示)
你的程序将对给定的n,计算并输出由操作数序列1,2,…,n经过操作可能得到的输出序列的总数。
解决方法:
这道题目是典型的卡特兰数的应用
其前几项为1, 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, …
通项公式为:

其他经典的运用卡特兰数的问题有:

  • 矩阵连乘打括号
  • 出栈次序
  • 凸多边形三角划分
  • 给定结点组成二叉搜索树
  • n对括号正确匹配数目
原创粉丝点击