C#学习笔记之——矩形覆盖问题

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

首先我们来画个图

1

只有一种情况

2

有两种情况

3

有三种情况

4,以此类推,2*4的矩形有5种

5    2*5的矩形有8种,可以发现这个是类似斐波那契数列的形式

不使用递归

public int rectCover(int number)
{
    // write code here
    int sum = 0;
    int a = 1, b = 2;
    if (number <= 0)
        sum = 0;
    else if (number == 1)
        sum = 1;
    else if (number == 2)
        sum = 2;
    else
        for (int i = 3; i <= number; i++)
        {
            sum = a + b;
            a = b;
            b = sum;
        }
    return sum;
}

使用递归

public int RectCover(int target) {
    if (target < 1)
        return 0;
    else if (target == 1 || target == 2)
        return target;
    else
        return RectCover(target-1) + RectCover(target-2);

}

 

posted @ 2019-06-08 10:50  养鼠的猫  阅读(174)  评论(0编辑  收藏  举报