码迷,mamicode.com
首页 > 编程语言 > 详细

[剑指offer] 10. 旋转数组的最小数字

时间:2018-12-01 13:24:59      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:otto   color   bottom   margin   int   ber   off   最小数   规律   

题目描述

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

思路:
利用dp[i]保存盖2*i的矩形有多少种办法。
通过摆前几个推算出规律
1 时候就是 |
2 时候就是 | | 和 --
摆n的时候就是两种情况,一种是先摆1格,则有dp[n-1]种方法 另一种是先2格,则有dp[n-2]种方法。
于是推出dp[n]=d[n-1]+dp[n-2]
class Solution
{
public:
  int rectCover(int number)
  {
    int dp[9999] = {0};
    dp[1] = 1;
    dp[2] = 2;

    for (int i = 3; i <= number; i++)
    {
      dp[i] = dp[i - 1] + dp[i - 2];
    }
    return dp[number];
  }
};

 

[剑指offer] 10. 旋转数组的最小数字

标签:otto   color   bottom   margin   int   ber   off   最小数   规律   

原文地址:https://www.cnblogs.com/ruoh3kou/p/10048344.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!