【回溯法】出栈序列统计

问题 J: 【回溯法】出栈序列统计

时间限制: 1 Sec  内存限制: 128 MB
提交: 18  解决: 12
[提交][状态][讨论版]

题目描述

栈是常用的一种数据结构,有n令元素在栈顶端一侧等待进栈,栈顶端另一侧是出栈序列。你已经知道栈的操作有两·种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出。现在要使用这两种操作,由一个操作序列可以得到一系列的输出序列。请你编程求出对于给定的n,计算并输出由操作数序列1,2,…,n,经过一系列操作可能得到的输出序列总数。

输入

一个整数n(1<=n<=15)

输出

一个整数,即可能输出序列的总数目。

样例输入

3

样例输出

5


解题思路:这个序列符合卡特兰数,卡塔兰数的一般项公式为 
  C_n = \frac{1}{n+1}{2n \choose n} = \frac{(2n)!}{(n+1)!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, ...
  
 于是直接打表提交了。^_^
  (其实这个题还有回溯和动态规划方法!)

代码:
#include <iostream>

using namespace std;

int main()
{
    int b;
    int a[16]={1,2,5,14,42,132,429,1430,4862, 16796, 58786, 208012, 742900, 2674440, 9694845};
    cin>>b;
    cout<<a[b-1];
    return 0;
}

 



posted @ 2016-08-09 10:04  多一份不为什么的坚持  阅读(385)  评论(0编辑  收藏  举报