解答牛顿爬楼梯问题

简介: 今天面试遇到了这个题,脑子轴了一下, 没有答上来, 事后想了想, 其实也是蛮简单的问题牛顿爬楼梯.png爬楼梯一次只能迈一节或二节台阶.

今天面试遇到了这个题,脑子轴了一下, 没有答上来, 事后想了想, 其实也是蛮简单的问题

牛顿爬楼梯.png

爬楼梯一次只能迈一节或二节台阶. 假设一共N节台阶. 那么一共有多少种方法呢?
分析问题的关键: 最后一步迈了几个格子?
如果最后一步迈了一个格子: 前面所有步法的数量为f(N-1)
如果最后一步迈了两个格子: 前面所有步法的数量为f(N-2)

"""
一个人一次可以迈过一节楼梯, 或者两节楼梯
问 N节楼梯有多少种走法?
分析: 
1节楼梯有1种走法
2节楼梯有2种走法

3节楼梯的走法数量 = 2节楼梯的走法数量(最后一次走一步的数量) + 1节楼梯的走法数量(最后一次走两步的数量)
N节楼梯的走法数量 = N-1 节楼梯的走法数量 + N-2节楼梯的走法数量

f(N) = f(N-1) + f(N-2)

"""

def take_1_2_stairs(N):

    if N == 1:
        return 1

    if N == 2:
        return 2

    return take_1_2_stairs(N-1) + take_1_2_stairs(N-2)


"""
f(N) = f(N-1) + f(N-2) + f(N-3)
"""
# 如果最多能迈三节
def take_1_2_3_stairs(N):
    if N == 1:
        return 1
    if N == 2:
        return 2
    if N == 3:
        return 4

    return take_1_2_3_stairs(N-1) + take_1_2_3_stairs(N-2) + take_1_2_3_stairs(N-3)


def main():
    result_1_2 = take_1_2_stairs(10)
    result_1_2_3 = take_1_2_3_stairs(10)
    print("如果每次迈出1-2个台阶, 共有",result_1_2, "种解法")
    print("如果每次迈出1-3个台阶,共有", result_1_2_3, "种走法")

if __name__ == '__main__':
    main()

这里用到了类似斐波那契的递推, 但实际上每次的结果取决于上一次保存的状态,是动态规划法的一种表现形式

目录
相关文章
|
3月前
|
算法 安全 Java
非启发式算法——中国剩余定理
非启发式算法——中国剩余定理
50 0
|
6月前
数论——高斯消元
数论——高斯消元
34 0
|
3月前
|
机器学习/深度学习 算法 C++
【动态规划】C++算法:403.青蛙过河
【动态规划】C++算法:403.青蛙过河
|
9月前
|
人工智能 算法
算法提高:组合数学| 容斥原理常见应用
容斥原理常见的问题如下。 (1) 篮球、羽毛球、网球三种运动,至少会一种的有22人,会篮球的有15人,会羽毛球的有17人,会网球的有12人,既会篮球又会羽毛球的有11人,既会羽毛球又会网球的有7人,既会篮球又会网球的有9人,那么三种运动都会的有多少人? (2) 《西游记》《三国演义》《红楼梦》三大名著,至少读过其中一本的有20人,读过《西游记》的有10人,读过《三国演义》的有12人,读过《红楼梦》的有15人,读过《西游记》《三国演义》的有8人,读过《三国演义》《红楼梦》的有9人,读过《西游记》《红楼梦》的有7人。问三本书全都读过的有多少人?
100 0
算法提高:组合数学| 容斥原理常见应用
|
9月前
|
机器学习/深度学习 算法
算法提高:组合数学| 卡特兰数的实现
卡特兰数列是组合数学中在各种计数问题中常出现的数列,其前几项为1,1,2,5,14,42,132,429,1430,4862,16796,58786,208012…… 卡特兰数首先是由欧拉在计算对凸n边形的不同的对角三角形剖分的个数问题时得到的,即在一个凸n边形中,通过不相交于n边形内部的对角线,把n边形拆分成若干三角形,不同的拆分数用Hn表示,Hn即卡特兰数。
82 0
算法提高:组合数学| 卡特兰数的实现
|
算法
算法简单题,吾辈重拳出击 - 动态规划之爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
|
算法 Windows
算法简单题,吾辈重拳出击 - 第 N 个泰波那契数
听说过斐波那契数列,那你听说过泰波那契数列吗?
|
机器学习/深度学习 算法
模拟退火-n皇后问题
模拟退火-n皇后问题
|
算法
贪心算法——小船过河
贪心算法——小船过河
319 0
贪心算法——小船过河
LDUOJ——山(计算几何+二分+精度)
LDUOJ——山(计算几何+二分+精度)
69 0