码迷,mamicode.com
首页 > 其他好文 > 详细

【校招面试 之 剑指offer】第10-3题 矩阵覆盖问题

时间:2018-07-24 11:18:28      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:ret   mes   分析   mat   idt   off   return   cpp   stream   

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

技术分享图片

分析:当放第一块时(假定从左边开始)可以横着放,也可以竖着放,记总的情况为f(8)。如果是竖着放,则记下来还有f(7)种放法;若是横着放,则下一块必须横着放,则还有f(6)种放法。

所以可以推导出公式:f(1) = 1 f(2) = 2 f(n)(n为偶数) = f(n-1)+f(n-2);

#include<iostream>
#include<math.h>
using namespace std;

// 
int matrixCover(int n){
	if(n == 1)
		return 1;
	if(n == 2)
		return 2;
	return matrixCover(n - 1) + matrixCover(n - 2);
}

int main(){

	// 矩阵覆盖问题
	cout<<"有 "<<matrixCover(8)<<" 种覆盖方法"<<endl;
	system("pause");
	return 0;
}

 

【校招面试 之 剑指offer】第10-3题 矩阵覆盖问题

标签:ret   mes   分析   mat   idt   off   return   cpp   stream   

原文地址:https://www.cnblogs.com/xuelisheng/p/9358714.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!