《剑指offer》— JavaScript(10)矩形覆盖

矩形覆盖

题目描述

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


实现代码

function jumpFloor(number)
{
    if (number<0){
        return -1;
    }else if(number <=2){
        return number
    }
    var arr = [];
    arr[0] = 1;
    arr[1] = 2;
    for(var i = 2; i < number; i++) {
        arr[i] = arr[i - 1] + arr[i - 2];
    }
    return arr[number-1];

思路

1. 先上图:
  2*1的大矩形和2*n的小矩形:

图片.png

2. 第一次覆盖有两种情况:
  横着覆盖:

图片.png

竖着覆盖:

图片.png

3. 由此可得:

  • 当第一次横着覆盖时,覆盖方法为f(n-2);
  • 当第一次竖着覆盖时,覆盖方法为f(n-1);
  • 因此f(n)=f(n-1)+f(n-2);
  • 当n=1时,只有1种覆盖方法,当n=2时,有2种覆盖方法。
  • 此题最终得出的仍然是一个斐波那契数列。
    n=1, f(n)=1
    n=2, f(n)=2
    n>2,且为整数, f(n)=f(n-1)+f(n-2)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 矩阵覆盖 题目描述 我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*...
    McRay阅读 430评论 0 0
  • 1.二维数组中查找2.替换空格3.从尾到头打印链表4.重建二叉树5.用两个栈实现队列6.旋转数组的最小数字7.斐波...
    icecrea阅读 335评论 0 1
  • 本文出自 Eddy Wiki ,转载请注明出处:http://eddy.wiki/interview-code.h...
    eddy_wiki阅读 9,391评论 0 30
  • 感赏孩子爸爸大格局,正能量,是真心地爱孩子。给孩子买了电动车后,孩子隔三差五中午回来吃饭,这和之前他爸爸...
    王琛_Amy阅读 247评论 0 0
  • 文/周寒舟 1 夏黎撩了楼上公司新来的总经理祁琋。 原本男未婚女未嫁,权当追了次时下流行的撩汉潮流。真算不上什么大...
    周寒舟阅读 7,577评论 31 58