Day10 :矩形覆盖
时间:2022-07-24
本文章向大家介绍Day10 :矩形覆盖,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
剑指Offer_编程题——矩形覆盖
题目描述:
我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2 * 1的小矩形无重叠地覆盖一个2 * n的大矩形,总共有多少种方法?不如n=3时,2 * 3的矩形块有3种覆盖方法
具体要求:
时间限制: C/C++ 1秒,其他语言2秒 空间限制: C/C++32M,其他语言64M
具体思路:
本题还是递归,前面的3题都是递归,依旧是通过一个实际问题来考察递归,可见递归的重要性。根据题意:当n=1时,f(n) = 1;当n=2时,f(n) = 2;当n = 3时,f(3) = 3;……以此类推:f(n) = f(n-1) + f(n-2);因此是递归。 我们用java来实现这个思路。
public class Solution{
public int RectCover(int target){
if (target == 1)
return 1;
if (target == 2)
return 2;
int f1 = 1, f2 = 2, f3 = 0;
for (int i = 3; i <= target; i++){
f3 = f1 + f2;
f1 = f2;
f2 = f3;
}
return f3;
}
}
代码效果图如图所示:
接下来我们用python来实现:
class Solution:
def rectCover(self, number):
p =[1, 2]
if number == 0:
return 0;
while len(p) < number:
t = len(p)
s = p[0] * p[-1] + (p[1] - 1) * p[-2]
p.append(s)
return p[number - 1]
代码效果图如图所示:
总结
本道题继前面的几道题,继续考察递归,可见递归的重要性,均是以实际问题引入,通过自己总结规律得出本题的考察点是递归。递归一直是重点,并且还会结合一些其他的知识点一起考察,很少单独命题。比如递归+查找或者递归+贪心算法等,还需要我们继续刷题,继续总结。总之,继续加油,争取早日找到工作,Good Luck!!!
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 手写一个JDK1.7的简版HashMap
- MySQL存储过程创建与使用
- 一些有意思的JavaScript代码片段
- Flutter 完成全平台制霸:实现 Windows 应用支持
- python包:urllib——使用urllib下载无限制链接图片
- 初探 TensorFlow.js
- 如何使用 Apache Directory Studio 连接 JumpCloud
- 0812-5.16.2-如何获取CDSW上提交Spark作业的真实用户
- GLMM:广义线性混合模型(遗传参数评估)
- 特征锦囊:今天一起搞懂机器学习里的L1与L2正则化
- 【一天一大 lee】二叉搜索树的最近公共祖先 (难度:简单) - Day2020092
- Spring多数据源事务如何玩? | Spring系列46篇
- 使用Mfuzz包做时间序列分析
- 网络安全 | 瑞哥带你全方位解读防火墙技术!
- 【SpringBoot DB 系列】Jooq 之新增记录使用姿势