题解

矩形覆盖

http://www.nowcoder.com/questionTerminal/72a5a919508a4251859fb2cfb987a0e6

描述:

这是一道规律题。
知识点:递归,记忆递归,动态规划,递推
难度::一星
对应的题解视频:



题解:

方法一:递推


对于这种题没有思路怎么办?
那就对n 从小到大,一步步分析:

n=1时,显然只有一种方法

n=2时,如图有2种方法
n=3,如图有3中方法

n=4,如图有4种方法。

如果到这里,还没有发现规律怎么办呢?
那我们就再分析以下,从n=3到n=4,怎么来的呢?
这里有2种情况:
  • 直接在n=3的情况下,再后面中添加一个竖着的。这个很显然成立,有3种情况
  • 然后横着的显然能添加到n-2的情况上,也就是在n=2后面,添加2个横着的。有2种情况
通过以上分析,发现刚好和图中的个数一样。
所以总结:f [n]表示2*n大矩阵 的方法数。
可以得出:f[n] = f[n-1] + f[n-2],初始条件f[1] = 1, f[2] =2
所以代码可用递归,记忆递归,和动态规划和递推
这里只写递推代码:


int rectCover(int n) {
    if (n==0 || n==1 || n==2) return n;
    int a = 1, b = 2, c;
    for (int i=3; i<=n; ++i) {
        c = a + b;
        a = b;
        b = c;
    }
    return c;
}


全部评论

相关推荐

评论
3
1
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
10315次浏览 92人参与
# 你的实习产出是真实的还是包装的? #
1836次浏览 42人参与
# 米连集团26产品管培生项目 #
5892次浏览 215人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7537次浏览 43人参与
# 简历第一个项目做什么 #
31643次浏览 333人参与
# 重来一次,我还会选择这个专业吗 #
433423次浏览 3926人参与
# MiniMax求职进展汇总 #
23967次浏览 308人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187071次浏览 1122人参与
# 牛客AI文生图 #
21418次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152338次浏览 887人参与
# 研究所笔面经互助 #
118892次浏览 577人参与
# 简历中的项目经历要怎么写? #
310182次浏览 4202人参与
# AI时代,哪些岗位最容易被淘汰 #
63576次浏览 813人参与
# 面试紧张时你会有什么表现? #
30502次浏览 188人参与
# 你今年的平均薪资是多少? #
213063次浏览 1039人参与
# 你怎么看待AI面试 #
179990次浏览 1245人参与
# 高学历就一定能找到好工作吗? #
64323次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76474次浏览 374人参与
# 我的求职精神状态 #
448028次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363346次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160627次浏览 1111人参与
# 校招笔试 #
470762次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务