矩形覆盖

Posted ustca

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了矩形覆盖相关的知识,希望对你有一定的参考价值。

题目描述

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

思路

斐波那契问题。
时间复杂度O(n),空间复杂度O(1)。

代码

public class Solution {
    public int RectCover(int target) {
        if(target < 1)    return 0;
        if(target < 3)    return target;
        int f1 = 1, f2 = 2, tmp = 0;
        for(int i = 2; i < target; i++) {
            tmp = f1 + f2;
            f1 = f2;
            f2 = tmp;
        }
        return f2;
    }
}

以上是关于矩形覆盖的主要内容,如果未能解决你的问题,请参考以下文章

n个2*1小矩形无重叠覆盖2*n大矩形(递归,思路分析及代码实现,斐波那契数列衍生)

小矩形覆盖大矩形问题

小矩形覆盖大矩形问题

矩形覆盖

剑指offer 10.矩形覆盖

剑指offer 矩形覆盖