动态规划 Leetcode 70 爬楼梯
爬楼梯
Leetcode 70
学习记录自代码随想录
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
示例 1:
输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶
示例 2:
输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
- 1 阶 + 1 阶 + 1 阶
- 1 阶 + 2 阶
- 2 阶 + 1 阶
提示:
1 <= n <= 45
要点:1.明确动态规划每个步骤的具体含义
class Solution {
public:int climbStairs(int n) {if(n == 1 || n == 2) return n;// 1.确定动态规划数组和下标含义(此处需要考虑0层楼梯对应几,爬0层楼梯不用方法即为0)vector<int> dp(n+1);// 2. 确定递推公式,n>2,dp[i] = dp[i-1] + dp[i-2]// 3. dp数组初始化dp[1] = 1;dp[2] = 2;// 4. 确定遍历顺序,从前向后for(int i = 3; i < n; i++){dp[i] = dp[i-1] + dp[i-2];}// 5. 举例推导dp数组,1,2,3,5,8,……return dp[n]; }
};
相关文章:
动态规划 Leetcode 70 爬楼梯
爬楼梯 Leetcode 70 学习记录自代码随想录 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n 2 输出:2 解释:有两种方法可以爬到…...
(未解决)macOS matplotlib 中文是方框
reference: Mac OS系统下实现python matplotlib包绘图显示中文(亲测有效)_mac plt 中文值-CSDN博客 module ‘matplotlib.font_manager‘ has no attribute ‘_rebuild‘解决方法_font_manager未解析-CSDN博客 # 问题描述(笑死 显而易见 # solve 找到…...
深入探讨C#中的递归算法
一、什么是递归算法? 递归是指一个函数或方法在执行过程中调用自身的情况。递归算法是编程中常见的一种解决问题的方法。它将一个问题分解成一个或多个与原问题相似但规模更小的子问题,然后通过解决这些子问题来解决原问题。递归算法通常用于解决重复性的…...
三款顶级开源RAG (检索增强生成)工具:Verba、Unstructured 和 Neum
三款顶级开源RAG (检索增强生成)工具:Verba、Unstructured 和 Neum 概述 随着企业对话式数据处理需求的提升,面临的挑战是数据隐私性和缺乏企业级解决方案。虽然类似LangChain能在短时间内构建RAG应用,但忽视了文档解析、多来源数据ETL、批量…...
VC++、MFC中操作excel时,CRange中get_EntireRow()和get_EntireColumn()函数的用法及区别是什么?
在VC和MFC中操作Excel时,通过COM接口与Excel交互时,CRange 对象(或更准确地说是 Excel::Range 对象)代表一个单元格范围。CRange 类提供了一系列方法来获取或操作这个范围内的单元格。其中,get_EntireRow() 和 get_Ent…...
npm 操作报错记录1- uninstall 卸载失效
npm 操作报错记录1- uninstall 卸载失效 1、问题描述 安装了包 vue/cli-plugin-eslint4.5.0 vue/eslint-config-prettier9.0.0 但是没有使用 -d ,所以想重新安装,就使用 uninstall 命令卸载,结果卸载了没反应,也没有报错…...
openCV保存图像
保存图像 //保存为png透明通道vector<int>opts;opts.push_back(IMWRITE_PAM_FORMAT_RGB_ALPHA);imwrite("D:/img_bgra.png", img, opts);//保存为单通道灰度图像img cv::imread(imagePath.toStdString(), IMREAD_GRAYSCALE);vector<int> opts_gray;opts…...
mac 配置.bash_profile不生效问题
1、问题描述 mac系统中配置了环境变量只能在当前终端生效,切换了终端就无效了,查了下问题所在。mac系统会预装一个终极shell - zsh,环境变量读取在 .zshrc 文件下。 2、解决方案 1、切换终端到bash 切换终端到bash chsh -s /bin/bash 切换终端…...
【Cesium for Supermap】S3MTiles图层box裁剪
效果图: 代码: let viewer new Cesium.Viewer(cesiumContainer);// 添加SuperMap iServer发布的S3M缓存服务let promise viewer.scene.addS3MTilesLayerByScp("http://www.supermapol.com/realspace/services/3D-BIMbuilding/rest/realspace/data…...
PAT部分题目相关知识点——python
python中的整除 在Python中,整除(也称为地板除)可以使用**//**运算符来实现。当使用//运算符时,结果将是一个整数,它表示除法运算的整数部分,舍去任何小数部分。 示例: # 使用整除运算符 // …...
Redis核心数据结构之字典(二)
字典 解决键冲突 当有两个或以上数量的键被分配到了一个哈希表数组的同一个索引上面,我们称这些键发生了冲突(collision)。 Redis的哈希表使用链地址法(separate chaining)来解决键冲突,每个哈希表节点都有一个next指针,多个哈希表节点可以…...
拯救行动(BFS)
公主被恶人抓走,被关押在牢房的某个地方。牢房用 N \times M (N, M \le 200)NM(N,M≤200) 的矩阵来表示。矩阵中的每项可以代表道路()、墙壁(#)、和守卫(x)。 英勇的骑士(r…...
985硕的4家大厂实习与校招经历专题分享(part2)
我的个人经历: 985硕士24届毕业生,实验室方向:CV深度学习 就业:工程-java后端 关注大模型相关技术发展 校招offer: 阿里巴巴 字节跳动 等10 研究生期间独立发了一篇二区SCI 实习经历:字节 阿里 京东 B站 (只看大厂,面试…...
【NR技术】 3GPP支持无人机的关键技术以及场景
1 背景 人们对使用蜂窝连接来支持无人机系统(UAS)的兴趣浓厚,3GPP生态系统为UAS的运行提供了极好的好处。无处不在的覆盖范围、高可靠性和QoS、强大的安全性和无缝移动性是支持UAS指挥和控制功能的关键因素。与此同时,监管机构正在调查安全和性能标准以及…...
【译】WordPress Bricks主题安全漏洞曝光,25,000个安装受影响
WordPress的Bricks主题存在一个严重的安全漏洞,恶意威胁行为者正在积极利用该漏洞在易受攻击的安装上运行任意PHP代码。 该漏洞被跟踪为CVE-2024-25600(CVSS评分:9.8),使未经身份验证的攻击者能够实现远程代码执行。它…...
【C++ 23种设计模式】
C 23种设计模式 ■ 创建型模式(5种)■ 工厂模式■ 抽象工厂模式■ 原型模式■ 单例模式■ 第一种:单线程(懒汉)■ 第二种:多线程(互斥量实现锁懒汉)■ 第三种:多线程(const static饿…...
亚信安慧AntDB:企业数据管理的明日之星
在信息科技飞速发展的时代,亚信科技AntDB团队提出了一项颠覆性的“超融合”理念,旨在满足企业日益增长的复杂混合负载和多样化数据类型的业务需求。这一创新性框架的核心思想在于融合多引擎和多能力,充分发挥分布式数据库引擎的架构优势&…...
Android Gradle开发与应用 (三) : Groovy语法概念与闭包
1. Groovy介绍 Groovy是一种基于Java平台的动态编程语言,与Java是完全兼容,除此之外有很多的语法糖来方便我们开发。Groovy代码能够直接运行在Java虚拟机(JVM)上,也可以被编译成Java字节码文件。 以下是Groovy的一些…...
Android 14 设置锁屏为NONE后开启双卡PIN锁,重启设备后,输完卡1的PIN码就进入了安卓界面,未提示输入卡2的PIN码
一.问题背景 目前在多个Android14平台发现开启双卡PIN码并且关闭屏幕锁的情况下,第二个PIN码锁输入弹框不能弹出问题,导致第二个卡不能注网。 如下是未修改前重启后解锁卡1PIN码的状态 可以看出卡2不能正常使用 二.何处关闭了卡2的PIN锁? 1.添加日志 首先在KeyguardSecu…...
2024 GoLand激活,分享几个GoLand激活的方案
文章目录 GoLand公司简介我这边使用GoLand的理由GoLand 最新变化GoLand 2023.3 最新变化AI Assistant 正式版GoLand 中的 AI Assistant:_Rename_(重命名)GoLand 中的 AI Assistant:_Write documentation_(编写文档&…...
Webots仿真进阶:如何用编码器和激光雷达数据,让机器人‘感知’自己的速度与环境?
Webots仿真进阶:编码器与激光雷达数据融合实现机器人自主感知 在机器人仿真开发中,让机器人真正"活起来"的关键在于赋予其环境感知能力。想象一下,当你的机器人不仅能按照预设路径移动,还能实时感知自身速度和周围障碍物…...
WeChatExporter:你的微信记忆守护者,一键解锁被封存的聊天时光
WeChatExporter:你的微信记忆守护者,一键解锁被封存的聊天时光 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 还记得那些深夜的长谈吗࿱…...
别再只会点灯了!用Arduino Uno和几个传感器模块,做个能听会看的小夜灯(附完整代码)
用Arduino Uno打造智能交互小夜灯:从环境感知到用户反馈的全流程实战 当夜幕降临,一盏能自动感知环境光线、响应用户操作的小夜灯,远比普通灯具更贴心实用。今天我们将用Arduino Uno开发板,配合光敏电阻、按键和蜂鸣器三个基础传感…...
React Fiber 架构的调度机制原理
React Fiber 架构的调度机制原理 React Fiber 是 React 16 引入的全新核心算法,旨在解决传统堆栈调和(Stack Reconciler)在复杂应用中的性能瓶颈。其核心思想是通过可中断、优先级驱动的调度机制,将渲染任务拆分为多个小任务&…...
egergergeeert部署案例:CSDN GPU平台7860端口Web服务搭建全记录
egergergeeert部署案例:CSDN GPU平台7860端口Web服务搭建全记录 1. 项目背景与镜像介绍 egergergeeert 是一套专为图像创作场景设计的文生图AI镜像,能够通过简单的提示词输入直接生成高质量图片。这套解决方案特别适合需要快速生成插画草图、角色设计图…...
游戏版本,数据被盗如何预防
服务器被人入侵与被流量攻击,是GM经常会遇到的两个问题。流量攻击会导致服务器黑洞封停,用户无法访问,业务中断。机器被入侵,版本数据被盗,他人开了相同的游戏,也会给自己带来竞争压力。服务器平时要如何预…...
【限时技术红利】C# 14原生AOT + Dify客户端 = 独立单文件.exe部署,告别运行时依赖——但仅适用于.NET 9 Preview 5+
第一章:C# 14原生AOT部署Dify客户端的演进背景与技术定位近年来,AI服务客户端对启动性能、内存占用和分发体积提出更高要求。Dify作为开源LLM应用编排平台,其官方SDK长期依赖.NET运行时动态加载与JIT编译机制,在边缘设备、Serverl…...
LightOnOCR-2-1B与VSCode开发环境配置指南
LightOnOCR-2-1B与VSCode开发环境配置指南 1. 开发环境准备 在开始使用LightOnOCR-2-1B进行文档识别开发之前,我们需要先配置一个高效的VSCode开发环境。这个模型是一个10亿参数的端到端视觉语言模型,专门用于将PDF、扫描件和图像转换为结构化的文本内…...
Go语言的reflect.StructOf动态创建结构体类型与运行时元编程能力
Go语言作为一门静态类型语言,其强大的反射机制为开发者提供了突破静态限制的可能。其中,reflect.StructOf函数作为运行时元编程的核心工具之一,允许程序在运行时动态创建结构体类型,为框架开发、协议解析等场景带来极大灵活性。本…...
JDK1.8环境下的传统系统AI升级:忍者像素绘卷与Java老项目集成
JDK1.8环境下的传统系统AI升级:忍者像素绘卷与Java老项目集成 1. 老系统AI升级的痛点与机遇 很多企业还在使用JDK1.8这样的老版本Java环境运行核心业务系统。这些系统通常已经稳定运行多年,但面临智能化升级的需求。传统系统引入AI能力时,常…...
