题目描述
我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
比如n=3时,2*3的矩形块有3种覆盖方法:

思路:与裴波拉契数列思路一致。
1 public int RectCover(int target) { 2 if(target<1){ 3 return 0; 4 } 5 else if(target==2||target==1){ 6 return target; 7 } 8 else{ 9 return RectCover(target-1)+RectCover(target-2); 10 } 11 }