凸n边形的不同划分方式 C++题解

凸n边形的不同划分方式

内存限制: 128 MiB时间限制: 1000 ms标准输入输出题目类型: 传统评测方式: 文本比较

题目描述

卡特兰数又称卡塔兰数,英文名Catalan number,是组合数学中一个常出现在各种计数问题中出现的数列。以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)的名字来命名。

最初,给卡塔兰数建立的数学模型是:一个凸n边形,通过不相交于n边形内部的对角线,把n边形拆分成若干三角形,不同的拆分数目用hn表示,hn即为Catalan数。例如五边形有如下五种拆分方案(如图),故h5=5。求对于一个任意的凸n边形相应的hn。

avatar

输入格式

一个正整数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;
} 
  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值