数组03--矩阵覆盖-jz10

题目概述

  • 算法说明
    我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2n的大矩形,总共有多少种方法?
    比如n=3时,2
    3的矩形块有3种覆盖方法,如下图所示:
  • 数组03--矩阵覆盖_递归

  • 测试用例
    输入:
    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)
}

注意事项

  1. 为了减少内存开销,建议使用循环实现递归。

说明

  1. 当前使用 go1.15.8
  2. 参考​​牛客网--剑指offer​​ 标题中jzn(n为具体数字)代表牛客网剑指offer系列第n号题目,例如 jz01 代表牛客网剑指offer中01号题目。

注意!!!

  • 笔者最近在学习 golang,因此趁机通过数据结构和算法来进一步熟悉下go语言
  • 当前算法主要来源于剑指 offer,后续会进一步补充 LeetCode 上重要算法,以及一些经典算法
  • 此处答案仅为参考,不一定是最优解,欢迎感兴趣的读者在评论区提供更优解