首页 > 其他 > 详细

JZ10 矩形覆盖

时间:2021-08-30 11:55:06      阅读:6      评论:0      收藏:0      [点我收藏+]

描述

我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,从同一个方向看总共有多少种不同的方法?
 
比如n=3时,2*3的矩形块有3种不同的覆盖方法(从同一个方向看):
技术分享图片

输入描述:

2*1的小矩形的总个数n

返回值描述:

覆盖一个2*n的大矩形总共有多少种不同的方法(从同一个方向看)

示例1

输入:
0
返回值:
0

示例2

输入:
1
返回值:
1

示例3

输入:
4
返回值:
5

==================================================================================================================================

解题思路:
  本题为动态规划问题,掌握规律

当 n 为 1 时,只有一种覆盖方法:

技术分享图片

当 n 为 2 时,有两种覆盖方法:

技术分享图片

要覆盖 2*n 的大矩形,可以先覆盖 2*1 的矩形,再覆盖 2*(n-1) 的矩形;或者先覆盖 2*2 的矩形,再覆盖 2*(n-2) 的矩形。而覆盖 2*(n-1) 和 2*(n-2) 的矩形可以看成子问题。该问题的递推公式如下:

技术分享图片

JZ10 矩形覆盖

原文:https://www.cnblogs.com/hddandelion/p/15196066.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!