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

day38 ● 理论基础 ● 509. 斐波那契数 ● 70. 爬楼梯 ● 746. 使用最小花费爬楼梯

509. 斐波那契数

斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:

F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1

给定 n ,请计算 F(n) 。

示例 1:

输入:n = 2
输出:1
解释:F(2) = F(1) + F(0) = 1 + 0 = 1

示例 2:

输入:n = 3
输出:2
解释:F(3) = F(2) + F(1) = 1 + 1 = 2

示例 3:

输入:n = 4
输出:3
解释:F(4) = F(3) + F(2) = 2 + 1 = 3

class Solution:def fib(self, n: int) -> int:if n==0:return 0#创建dp数组dp=[0]*(n+1)#初始化dp数组dp[0]=0dp[1]=1#确定遍历:从前到后,因为要使用前面的状态for i in range(2,n+1):# 确定递归公式/状态转移公式dp[i]=dp[i-1]+dp[i-2]return dp[n]

70. 爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

class Solution:def climbStairs(self, n: int) -> int:if n==1:return 1dp=[0]*(n+1)dp[1]=1dp[2]=2for i in range(3,n+1):dp[i]=dp[i-1]+dp[i-2] #dp[i]包含dp[i-1]和dp[i-2]的两种情况return dp[n]

746. 使用最小花费爬楼梯

给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

示例 1:

输入:cost = [10,15,20]
输出:15
解释:你将从下标为 1 的台阶开始。
- 支付 15 ,向上爬两个台阶,到达楼梯顶部。
总花费为 15 。

示例 2:

输入:cost = [1,100,1,1,1,100,1,1,100,1]
输出:6
解释:你将从下标为 0 的台阶开始。
- 支付 1 ,向上爬两个台阶,到达下标为 2 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 4 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 6 的台阶。
- 支付 1 ,向上爬一个台阶,到达下标为 7 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 9 的台阶。
- 支付 1 ,向上爬一个台阶,到达楼梯顶部。
总花费为 6 。
class Solution:def minCostClimbingStairs(self, cost: List[int]) -> int:dp=[0]*(len(cost)+1)dp[0]=0dp[1]=0for i in range(2,len(cost)+1):dp[i]=min(cost[i-1]+dp[i-1],cost[i-2]+dp[i-2])return dp[-1]

相关文章:

  • 生活使用英语口语柯桥外语学校成人英语学习
  • HBase中Master初始化错误~
  • STM32无法烧写程序的故障排除
  • Flink的简单学习五
  • 鸿蒙开发:【线程模型】
  • 测试bert_base不同并行方式下的推理性能
  • STM32--DMA
  • Comfyui容器化部署与简介
  • mysql log_bin
  • Next.js 加载页面及流式渲染(Streaming)
  • 小公司要求真高
  • 247 H指数
  • DolphinScheduler 3.x 执行insert into SQL任务显示成功,但查不到数据
  • 网络仿真方法综述
  • 优质短视频素材下载网站有哪些?分享优质短视频素材下载资源
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 【附node操作实例】redis简明入门系列—字符串类型
  • ECMAScript6(0):ES6简明参考手册
  • idea + plantuml 画流程图
  • Laravel核心解读--Facades
  • Netty 4.1 源代码学习:线程模型
  • nginx 配置多 域名 + 多 https
  • nodejs调试方法
  • Node项目之评分系统(二)- 数据库设计
  • springMvc学习笔记(2)
  • sublime配置文件
  • vue-loader 源码解析系列之 selector
  • 闭包--闭包之tab栏切换(四)
  • 京东美团研发面经
  • 来,膜拜下android roadmap,强大的执行力
  • 区块链将重新定义世界
  • 容器化应用: 在阿里云搭建多节点 Openshift 集群
  • 如何使用 JavaScript 解析 URL
  • 入门级的git使用指北
  • 删除表内多余的重复数据
  • 中国人寿如何基于容器搭建金融PaaS云平台
  • d²y/dx²; 偏导数问题 请问f1 f2是什么意思
  • ​比特币大跌的 2 个原因
  • ###C语言程序设计-----C语言学习(3)#
  • #HarmonyOS:基础语法
  • #Js篇:单线程模式同步任务异步任务任务队列事件循环setTimeout() setInterval()
  • #mysql 8.0 踩坑日记
  • $HTTP_POST_VARS['']和$_POST['']的区别
  • (env: Windows,mp,1.06.2308310; lib: 3.2.4) uniapp微信小程序
  • (八)Spring源码解析:Spring MVC
  • (二十三)Flask之高频面试点
  • (七)Knockout 创建自定义绑定
  • (强烈推荐)移动端音视频从零到上手(上)
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (转)淘淘商城系列——使用Spring来管理Redis单机版和集群版
  • (轉)JSON.stringify 语法实例讲解
  • *++p:p先自+,然后*p,最终为3 ++*p:先*p,即arr[0]=1,然后再++,最终为2 *p++:值为arr[0],即1,该语句执行完毕后,p指向arr[1]
  • .NET BackgroundWorker
  • .NET CORE 第一节 创建基本的 asp.net core
  • .net core 的缓存方案