当前位置: 首页 > news >正文

动态规划问题——青蛙跳台阶案例分析

问题描述:

一只青蛙要跳上n级台阶,它每次可以跳 1级或者2级。问:青蛙有多少种不同的跳法可以跳完这些台阶?

举个例子:

假设台阶数 n = 3 ,我们来看看青蛙有多少种跳法。 

可能的跳法:
1. 跳1级,再跳1级,再跳1级。(1+1+1)
2. 跳1级,再跳2级。(1+2)
3. 跳2级,再跳1级。(2+1)

所以,当 n = 3 时,总共有 3种跳法。

规律是什么?

我们可以发现,青蛙跳到第 \( n \) 级台阶的跳法数,取决于它跳到前两级台阶的跳法数:
1. 如果青蛙最后一步跳 1级,那么它之前一定是从第 n-1 级跳上来的。
2. 如果青蛙最后一步跳 2级,那么它之前一定是从第 n-2 级跳上来的。 

递推公式: 

f(n) = f(n-1) + f(n-2)
其中:
 f(1) = 1 (只有1级台阶,只有一种跳法)
 f(2) = 2 (2级台阶,可以跳1+1,或者直接跳2) 

具体计算:

我们用一个表格来计算 \( f(n) \) 的值: 

台阶数n跳法数f(n)计算方式
11只有一种跳法:1
22两种跳法:1+1或2
33f(2)+f(1)=2+1
45f(3)+f(2)=3+2
58f(4)+f(2)=5+3
.........

代码实现:

用代码来计算f(n)的值: 

def jump_ways(n):if n <= 0:return 0elif n == 1:return 1elif n == 2:return 2# 初始化前两级台阶的跳法数prev1, prev2 = 1, 2  # f(1) = 1, f(2) = 2# 从第3级开始计算for i in range(3, n + 1):current = prev1 + prev2prev1, prev2 = prev2, currentreturn prev2# 示例
n = 5
print(f"跳上 {n} 级台阶的跳法数:{jump_ways(n)}")

输出:

跳上 5 级台阶的跳法数:8 

总结:

 跳到第 n 级台阶的跳法数,等于跳到第 n-1 级的跳法数,加上跳到第n-2级的跳法数。
- 这个规律和斐波那契数列是一样的。
- 通过动态规划,我们可以高效地计算出结果。

http://www.lryc.cn/news/533632.html

相关文章:

  • element-ui使用el-table,保留字段前的空白
  • kamailio中路由模块汇总
  • 如何使用 DeepSeek 搭建本地知识库
  • 网络HTTP详细讲解
  • 《Origin画百图》之边际分布曲线图
  • 【Milvus】向量数据库pymilvus使用教程
  • React 生命周期函数详解
  • 第 26 场 蓝桥入门赛
  • 组合(力扣77)
  • 网络工程师 (22)网络协议
  • Linux之文件IO前世今生
  • 如何在Windows中配置MySQL?
  • Kafka 入门与实战
  • 数学知识学习1
  • 【AI日记】25.02.08
  • Lecture8 | LPV VXGI SSAO SSDO
  • Java中实现定时锁屏的功能(可以指定时间执行)
  • Java集合List详解(带脑图)
  • [实验日志] VS Code 连接服务器上的 Python 解释器进行远程调试
  • (14)gdb 笔记(7):以日志记录的方式来调试多进程多线程程序,linux 命令 tail -f 实时跟踪日志
  • Sentinel的安装和做限流的使用
  • 四柱预测学
  • 【个人开发】macbook m1 Lora微调qwen大模型
  • sqli-labs靶场实录(二): Advanced Injections
  • Linux系统 环境变量
  • 机器学习-线性回归(最大似然估计)
  • 【信息系统项目管理师-案例真题】2017上半年案例分析答案和详解
  • CSP晋级组比赛生成文件夹与文件通用代码Python
  • 正则表达式进阶(二)——零宽断言详解:\b \B \K \z \A
  • Android 中实现 PDF 预览三种方式