矩形覆盖
来源:互联网 发布:台视网络直播 编辑:程序博客网 时间:2024/05/18 07:52
题目描述
10、我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
解题思路:
1)、当 n = 1时,矩阵大小n = 2时,为2*1时,只有1种覆盖方法,即f(1) = 1;
2)、当 n = 2时,矩阵大小为2*2时,有2种覆盖方法,即f(2) = 2;
3)、当 n = 3时,矩阵大小为2*3时,有3种覆盖方法,即f(3) = 3;
4)、当然我们没必要一个个去列举所有的,直接假设有n个大小的2*1矩阵,即2*n矩阵进行考虑方法。
当第一次覆盖2*1的小矩阵(竖着放),则后面的覆盖方法为f(n-1);
当第一次覆盖1*2的小矩阵(横着放),对应下方的1*2的小矩阵摆放必然是确定的,所以后面的覆盖方法为f(n-2)。
所以总的覆盖方法为:f(n) = f(n-1) + f(n-2); 依旧是斐波那契数列的算法。
class Solution {
public:
int rectCover(int number) {
// 斐波那契 2017-6-18
if(number==1) return 1;
if(number==0) return 0;
if(number==2) return 2;
number-=2;
int f=1;
int s=2;
while(number--)
{
s=s+f;
f=s-f;
}
return s;
}
};
public:
int rectCover(int number) {
// 斐波那契 2017-6-18
if(number==1) return 1;
if(number==0) return 0;
if(number==2) return 2;
number-=2;
int f=1;
int s=2;
while(number--)
{
s=s+f;
f=s-f;
}
return s;
}
};
阅读全文
0 0
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- 矩形覆盖
- javascript 性能优化 -1
- 使用gdb调试多进程与多线程程序
- Python :圆圈中最后剩下的数
- [java]反射1
- Gerrit打包安装,只要下载一个文件就可以了
- 矩形覆盖
- Python :求1+2+3+...+n
- 素数距离问题
- if条件语句
- springmvc框架各组件功能理解
- Python :不用加减乘除做加法
- mac os x下配置Android Studio本地gradle
- ASoC框架详细分析
- React Native应用部署/热更新-CodePush最新集成总结(新)