码迷,mamicode.com
首页 > 其他好文 > 详细

不要搜索,出栈序列统计

时间:2017-04-05 23:52:05      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:geo   span   nbsp   5.5   来源   turn   return   blog   搜索   

1627: 出栈序列统计

时间限制: 1 Sec  内存限制: 128 MB

题目描述

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

 

输入

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

 

输出

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

 

样例输入

3

样例输出

5

提示

 

来源

搜索

这题虽然是搜索,但可以用卡特兰数做。

显然,搜索很麻烦。

至于为什么,正好有这个公式。

#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
    int n,f[20]={0};
    scanf("%d",&n);
    f[0]=1;f[1]=1;
    for(int i=2;i<=n;i++)
       for(int j=0;j<i;j++)
          f[i]+=f[j]*f[i-j-1];
          printf("%d\n",f[n]);
    return 0;
}
/*令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*/

 

不要搜索,出栈序列统计

标签:geo   span   nbsp   5.5   来源   turn   return   blog   搜索   

原文地址:http://www.cnblogs.com/themanintheworldismesbokeyuanbycnblogs/p/6670934.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!