(10)矩形覆盖

1.问题

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

2.思路

当target = n

上图中,如果填充第一个2n(绿色)的如图所示,那么就变成了RectCover(n-1)问题
下图中,如果填充第一个2
n(绿色)的如图所示,那么第二块砖必定是蓝色的砖块,问题变成了RectCover(n-2)问题.

3.代码

package test1_10;
/* * @author qianliu on 2019/4/21 14:45 * @Discription: * 1.问题:我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。 * 请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? */
public class Test10 {
    /* * 1.RectCover(1)=1 * 2.RectCover(2)=2,一种是横着放两块木头,一种是竖着放两根木头 * 3.RectCover(n)需要考虑: * 横着放第一块木头,那么就变成了第2块木头必须横放,后面就是RectCover(n-2) * 竖着放第一块木头,那么牛变成了RectCover(n-1) * */
    public static int RectCover(int target) {
        if(target <= 2) return target;

        return RectCover(target-1) + RectCover(target-2);
    }

    public static void main(String[] args) {
        System.out.println(RectCover(7));
    }
}

全部评论

相关推荐

joe2333:怀念以前大家拿华为当保底的日子
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务