凸n边形的不同划分方式
内存限制: 128 MiB时间限制: 1000 ms标准输入输出题目类型: 传统评测方式: 文本比较
题目描述
卡特兰数又称卡塔兰数,英文名Catalan number,是组合数学中一个常出现在各种计数问题中出现的数列。以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)的名字来命名。
最初,给卡塔兰数建立的数学模型是:一个凸n边形,通过不相交于n边形内部的对角线,把n边形拆分成若干三角形,不同的拆分数目用hn表示,hn即为Catalan数。例如五边形有如下五种拆分方案(如图),故h5=5。求对于一个任意的凸n边形相应的hn。
输入格式
一个正整数n,代表凸n边形的边数 (2≤n≤37)
输出格式
一个正整数,凸n边形划分成若干三角形的不同划分方式
样例
样例1输入
复制4
样例1输出
复制2
样例2输入
复制5
样例2输出
复制5
#include <bits/stdc++.h>
using namespace std;
int n;
long long h[45];
int main() {
scanf("%d", &n);
h[2] = 1;
for(int i = 3; i <= n; i++) {
for(int j = 2; j <= i - 1; j++) {
h[i] += h[j] * h[i - j + 1];
}
}
h[2] = 0;
printf("%lld", h[n]);
return 0;
}