hdu1143 Tri Tiling 递推

http://acm.hdu.edu.cn/showproblem.php?pid=1143


当n为奇数的时候是不能用2*1的方块摆满的,所以f[i] = 0;

当n为偶数的时可以这样划分,2和f[n-2],则有2*f[n-2]种,4和f[n-4]但是4的部分不能分解为2,2否则的话就跟2和f[n-2]这种情况重复了,在这种情况下只有两种摆法;接着是6和f[n-6],8和f[n-8].................f[0],这些情况都只有2种摆法。

递推方程f[n] = f[n-2]*f[2]+2*(f[n-4]+f[n-6]+f[n-8]............+f[0]);


#include<stdio.h>
#include<stdlib.h>


/*
递推方程:f[n] = f[n-2]*f[2]+2*(f[n-4]+f[n-6]+....+f[0]);
f[0] = 1;
*/


int main()
{
int n;
int i,j;
int temp;
int fn[31];
fn[0] = 1;
fn[1] = 0;
fn[2] = 3;
for(i = 4;i<31;i+=2)
{
fn[i] = fn[i-2]*fn[2];
fn[i-1] = 0;
temp = 0;
for(j = 4;j<=i;j+=2)
{
temp += fn[i-j];
}
fn[i] += temp*2;
}
while(scanf("%d",&n)!=EOF)
{
if(-1==n)
{
break;
}
printf("%d\n",fn[n]);
}
return 0;
}

你可能感兴趣的:(hdu1143 Tri Tiling 递推)