卡特兰数

区域赛系列一多边形划分

时间限制: 1000 ms  |  内存限制: 65535 KB
难度: 2
描述

Give you a convex(凸边形), diagonal n-3 disjoint divided into n-2 triangles(直线), for different number of methods, such as n=5, there are 5 kinds of partition method, as shown in Figure


 

输入
The first line of the input is a n (1<=n<=1000), expressed n data set.
The next n lines each behavior an integer m (3<=m<=18), namely the convex edges.
输出
For each give m,, output how many classification methods.
example output: Case #a : b
样例输入
3
3
4
5
样例输出
Case #1 : 1
Case #2 : 2
Case #3 : 5
卡特兰数,又是一种递推数列
卡特兰数又称卡塔兰数,英文名Catalan number,是组合数学中一个常出现在各种计数问题中出现的数列。由以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)命名,其前几项为 :
 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, ...

令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

另类递推式:

h(n)=h(n-1)*(4*n-2)/(n+1); 我比较喜欢这种方法简单明了。

递推关系的解为:

h(n)=C(2n,n)/(n+1) (n=0,1,2,...)

递推关系的另类解为:

h(n)=c(2n,n)-c(2n,n-1)(n=0,1,2,...)

就是一个简单递推的过程。说一下思路,一个(n)多边形分成多少三角形时,多边形每一个边都会组成一个三角形,就以这一条边两个点(作为 终点和起点)为界限,再找这个多边形任意一个点(pK)与这两个点连接起来,这样内部形成的三角形将多边形分成两个小多边形了(p(1~k) 和p(k~n))。它们的总共有多边形种类是这两个多边形的个数之积。又因为k的取值是(2~n-1)的。,将k取不同值的划分方案相加,得到的总方案数为:f(n)=f(2)f(n-2+1)+f(3)f(n-3+1)+……+f(n-1)f(2)。

代码如下:::需要注意的是要从第三项开始,也就是把第三项当成第一项。

long long a[20];
  a[1]=1;
  for(int i=2;i<=18;i++)
    a[i]=a[i-1]*(4*i-2)/(i+1);
  int   t,k=1;
  scanf("%d",&t);
  while(t--)
  {
      int n;
      scanf("%d",&n);
      printf("Case #%d : ",k++);
      printf("%lld\n",a[n-2]);
  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值