题目概述
- 算法说明
我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
比如n=3时,2*3的矩形块有3种覆盖方法,如下图所示:
- 测试用例
输入:
4
输出:
5
解析&参考答案
- 解析
方法1: 使用递归
方法2: 将递归更改为for循环,减少内存开销 - 参考答案
vim jz10.go
package main
import "fmt"
func rectCover(number int) int {
// 递归会超过内存
if number <= 0 {
return 0
}
if number == 1 || number == 2 {
return number
}
return rectCover(number-1) + rectCover(number-2)
}
func rectCoverV2(number int) int {
if number <= 0 {
return 0
}
if number == 1 || number == 2 {
return number
}
a, b := 1, 2
for i := 3; i <= number; i++ {
ret := a + b
a, b = b, ret
}
return b
}
func main() {
n := 4
//ret := rectCover(n)
ret := rectCoverV2(n)
fmt.Println(ret)
}
注意事项
- 为了减少内存开销,建议使用循环实现递归。
说明
- 当前使用 go1.15.8
- 参考 牛客网--剑指offer
标题中jzn(n为具体数字)代表牛客网剑指offer系列第n号题目,例如 jz01 代表牛客网剑指offer中01号题目。
注意!!!
- 笔者最近在学习 golang,因此趁机通过数据结构和算法来进一步熟悉下go语言
- 当前算法主要来源于剑指 offer,后续会进一步补充 LeetCode 上重要算法,以及一些经典算法
- 此处答案仅为参考,不一定是最优解,欢迎感兴趣的读者在评论区提供更优解