首页 > 其他 > 详细

矩形覆盖

时间:2016-09-04 19:25:18      阅读:196      评论:0      收藏:0      [点我收藏+]

我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?

 

 1 public class Solution {
 2     public int RectCover(int target) {
 3         if (target <= 0) { // target == 0,需要0个小矩形
 4             return 0;
 5         } else if (target == 1) { // target == 1,需要1个小矩形
 6             return 1;
 7         } else if (target == 2) { // tareget == 2,需要2个小矩形
 8             return 2;
 9         } else {
10             // target == n
11             // 分两种情况:1.第一个小矩形竖放,还有f(target-1)种方法;2.第一个矩形横放,还有f(n-2)种方法,因为第1个确定之后,第二个也就确定了。
12             return RectCover(target - 1) + RectCover(target - 2);
13         }
14     }
15 }

 

矩形覆盖

原文:http://www.cnblogs.com/jiangyi-uestc/p/5839949.html

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