骨牌铺方格
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 30790 Accepted Submission(s): 14905
Problem Description
在2×n的一个长方形方格中,用一个1× 2的骨牌铺满方格,输入n ,输出铺放方案的总数.
例如n=3时,为2× 3方格,骨牌的铺放方案有三种,如下图:
例如n=3时,为2× 3方格,骨牌的铺放方案有三种,如下图:
![](https://i-blog.csdnimg.cn/blog_migrate/396f212ed2d31ef1fd2e921eb1b248b2.jpeg)
Input
输入数据由多行组成,每行包含一个整数n,表示该测试实例的长方形方格的规格是2×n (0<n<=50)。
Output
对于每个测试实例,请输出铺放方案的总数,每个实例的输出占一行。
Sample Input
1 3 2
Sample Output
1 3 2解题思路:斐波拉契数列的应用源代码:#include <stdio.h> #include <stdlib.h> int main() { int i,n; long long a[51]={0,1,2}; for(i=3;i<51;i++) a[i]=a[i-1]+a[i-2]; while(scanf("%d",&n)!=EOF) { printf("%I64d\n",a[n]); } system("pause"); return 0; }拓展:有1×n的一个长方形,用1×1、1×2、1×3的骨牌铺满方格。例如当n=3时为1×3的方格(如图),此时用1×1,1×2,1×3的骨牌铺满方格,共有四种铺法。
输入: n(0<=n<=30); 输出: 铺法总数仔细分析最后一个格的铺法,发现无非是用1×1,1×2,1×3三种铺法,很容易就可以得出: f(n)=f(n-1)+f(n-2)+f(n-3); 其中f(1)=1,f(2)=2,f(3)=4