CS-Notes/notes/10.2 矩形覆盖.md

45 lines
1.5 KiB
Java
Raw Normal View History

2019-11-02 12:07:41 +08:00
# 10.2 矩形覆盖
2019-11-03 23:57:08 +08:00
## 题目链接
2022-01-07 09:00:01 +00:00
[牛客网](https://www.nowcoder.com/practice/72a5a919508a4251859fb2cfb987a0e6?tpId=13\&tqId=11163\&tPage=1\&rp=1\&ru=/ta/coding-interviews\&qru=/ta/coding-interviews/question-ranking\&from=cyc\_github)
2019-11-02 12:07:41 +08:00
## 题目描述
我们可以用 2\*1 的小矩形横着或者竖着去覆盖更大的矩形请问用 n 2\*1 的小矩形无重叠地覆盖一个 2\*n 的大矩形总共有多少种方法
2022-01-07 09:00:01 +00:00
![](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/b903fda8-07d0-46a7-91a7-e803892895cf.gif)\
2019-11-02 12:07:41 +08:00
## 解题思路
n 1 只有一种覆盖方法
2022-01-07 09:00:01 +00:00
![](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/f6e146f1-57ad-411b-beb3-770a142164ef.png)\
2019-11-02 12:07:41 +08:00
n 2 有两种覆盖方法
2022-01-07 09:00:01 +00:00
![](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/fb3b8f7a-4293-4a38-aae1-62284db979a3.png)\
2019-11-02 12:07:41 +08:00
要覆盖 2\*n 的大矩形可以先覆盖 2\*1 的矩形再覆盖 2\*(n-1) 的矩形或者先覆盖 2\*2 的矩形再覆盖 2\*(n-2) 的矩形而覆盖 2\*(n-1) 2\*(n-2) 的矩形可以看成子问题该问题的递推公式如下
2022-01-07 09:00:01 +00:00
![](https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/508c6e52-9f93-44ed-b6b9-e69050e14807.jpg)\
2019-11-02 12:07:41 +08:00
```java
2021-03-23 02:48:19 +08:00
public int rectCover(int n) {
2019-11-02 12:07:41 +08:00
if (n <= 2)
return n;
int pre2 = 1, pre1 = 2;
int result = 0;
for (int i = 3; i <= n; i++) {
result = pre2 + pre1;
pre2 = pre1;
pre1 = result;
}
return result;
}
```