我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
解析:
(1)当 n = 1时,只存在一种情况:
(2)当 n = 2时,存在两种情况:
(3)当 n >= 3时,分为两步考虑:
(3.1) 第一次摆放一块 2*1 的小矩阵,则余下的摆放方法总共为f(target - 1)
(3.2)第一次摆放一块1*2的小矩阵,则余下的摆放方法总共为f(target-2)
因为,摆放了一块12的小矩阵(用√√表示),对应下方的12(用××表示)摆放方法就确定了,所以为f(targte-2)
故得出结论:f(target) = f(target - 1)+ f(target - 2)
代码:
1 | public class Solution { |