剑指offer 矩阵覆盖

题目描述

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

思路

竖着的长度为n,横的长度为2

n = 1,明显只有一种方法,f(1) = 1

n = 2,小矩形全部横着放,或竖着放,两种方法,f(2) = 2

n = 3,如果横着放,那么还剩下 2 * 2 那么就是还有f(2)种方法,如果竖着放,那么旁边的一个 2 * 1也被固定下来,必须也竖着放,所以还有f(1)种方法,f(3) = f(2) + f(1)

为n的话,f(n) = f(n-1) + f(n-2),又是我们的斐波那契数列了。

代码

class Solution {
public:
    int rectCover(int number) {
        int front = 1, now = 2;
        if(number == 0)
        {
            return 0;
        }
        while(--number)
        {
            now = front + now;
            front = now - front;
        }
        return front;
    }
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。