leetcode 70 爬楼梯

简介: leetcode 70 爬楼梯

爬楼梯


b5ca42e3d5884c5f9a0f3d99c170048c.png

动态规划

爬到第一层楼梯有一种方法,爬到二层楼梯有两种方法。
那么第一层楼梯再跨两步就到第三层 ,第二层楼梯再跨一步就到第三层。
所以到第三层楼梯的状态可以由第二层楼梯 和 到第一层楼梯状态推导出来,那么就可以想到动态规划了。

我们来分析一下,动规五部曲:


定义一个一维数组来记录不同楼层的状态


确定dp数组以及下标的含义

dp[i]: 爬到第i层楼梯,有dp[i]种方法


从dp[i]的定义可以看出,dp[i] 可以有两个方向推出来。


首先是dp[i - 1],上i-1层楼梯,有dp[i - 1]种方法,那么再一步跳一个台阶不就是dp[i]了么。


还有就是dp[i - 2],上i-2层楼梯,有dp[i - 2]种方法,那么再一步跳两个台阶不就是dp[i]了么。


那么dp[i]就是 dp[i - 1]与dp[i - 2]之和!


所以dp[i] = dp[i - 1] + dp[i - 2] 。


我相信dp[1] = 1,dp[2] = 2,这个初始化大家应该都没有争议的。


所以我的原则是:不考虑dp[0]如果初始化,只初始化dp[1] = 1,dp[2] = 2,然后从i = 3开始递推,这样才符合dp[i]的定义。


确定遍历顺序

从递推公式dp[i] = dp[i - 1] + dp[i - 2];中可以看出,遍历顺序一定是从前向后遍历的

32c0ea307b9c476a9d0cdf1bcf3dc132.png

class Solution {
public:
    int climbStairs(int n) {
        if(n<=2) return n;
        vector<int> dp(n+1);
        dp[1] = 1;
        dp[2] = 2;
        for(int i=3 ;i<dp.size() ; i++)
        {
            dp[i] = dp[i-1] + dp[i-2]; 
        }
        return dp[n];
    }
};

完全背包

可以转换为完全背包,求排序数的问题

目标值就是楼梯的高度n,价值就是步子的高度1,2

class Solution {
public:
    int climbStairs(int n) {
        vector<int> step = {1,2};
        vector<int> dp(n+1,0);
        dp[0]  = 1;
        //求排序数,先遍历背包,后遍历价值
        for(int j=0 ; j<=n  ;j++)
        {
            for(int i=0 ; i<step.size();i++)
            {
                if(j>=step[i])
                {
                    dp[j] += dp[j-step[i]];
                }
                else dp[j] = dp[j];
            }
        }
        return dp[n];
    }
};

二刷

class Solution {
public:
    int climbStairs(int n) {
        if(n<=2) return n;
        vector<int> dp(n+1,0);
        dp[1] = 1;
        dp[2] = 2;
        for(int i=3 ; i<=n ; i++)
        {
            dp[i] = dp[i-1] + dp[i-2] ;
        }
        return dp[n];
    }
};
相关文章
|
监控 Windows
Windows系统中Wireshark抓包工具的安装使用
Windows系统中Wireshark抓包工具的安装使用
1704 0
|
9月前
|
存储 Java 物联网
如何快速开发一套智慧校园电子班牌系统?
简介:本文详解如何快速开发智慧校园电子班牌系统,涵盖技术栈选型、模块化开发策略、云端与终端协同方案,并提供源码二开建议,助力两个月内高效交付,适用于多校落地应用。
420 0
|
8月前
|
消息中间件 缓存 监控
中间件架构设计与实践:构建高性能分布式系统的核心基石
摘要 本文系统探讨了中间件技术及其在分布式系统中的核心价值。作者首先定义了中间件作为连接系统组件的&quot;神经网络&quot;,强调其在数据传输、系统稳定性和扩展性中的关键作用。随后详细分类了中间件体系,包括通信中间件(如RabbitMQ/Kafka)、数据中间件(如Redis/MyCAT)等类型。文章重点剖析了消息中间件的实现机制,通过Spring Boot代码示例展示了消息生产者的完整实现,涵盖消息ID生成、持久化、批量发送及重试机制等关键技术点。最后,作者指出中间件架构设计对系统性能的决定性影响,
|
分布式计算 安全 算法
【重磅】中国隐私计算平台市场,摩斯第一
10月11日,全球领先的IT市场研究和咨询公司IDC发布了《中国隐私计算平台厂商市场份额,2022》报告。蚂蚁集团凭借商用隐私计算平台摩斯(MORSE),以 36.9%的市场份额排名第一。
【重磅】中国隐私计算平台市场,摩斯第一
|
安全 开发者
在HTTPS安全页面中加载HTTP不安全的内容,如何绕过安全警告?
在HTTPS安全页面中加载HTTP不安全的内容,如何绕过安全警告?
1261 0
|
SQL Java 数据库连接
深入解析@MapperScan注解:简化MyBatis接口与映射器的关联
在Java持久化领域,MyBatis是一个广泛使用的ORM(对象关系映射)框架,用于将数据库中的数据映射到Java对象中。MyBatis的核心概念是SQL映射器(Mapper),它定义了数据库操作的方法。为了简化Mapper接口与映射器的关联,MyBatis提供了`@MapperScan`注解。本文将深入探讨`@MapperScan`注解的作用、用法,以及在MyBatis应用中的应用场景。
3495 0
|
机器学习/深度学习 数据可视化 TensorFlow
使用Python实现深度学习模型:智能旅游路线规划
使用Python实现深度学习模型:智能旅游路线规划
507 2
|
数据安全/隐私保护 UED 开发者
【Uniapp 专栏】Uniapp 项目中路由管理的实战经验分享
【5月更文挑战第12天】在 Uniapp 项目中,路由管理至关重要,涉及清晰的规划、配置和权限控制。合理设计路由结构便于开发维护,设置可读性高的页面路径和参数。根据场景选择参数传递和导航方式,处理嵌套路由,确保数据准确无误。添加权限判断保护受限页面,利用过渡动画提升用户体验。在复杂项目中,采用模块化管理路由,结合状态管理工具优化路由状态。持续测试和优化,以实现高效、流畅的用户导航。这些实战经验有助于提升 Uniapp 应用的质量。
572 6
|
安全 Java API
springboot 单点登录实现原理
【7月更文挑战第2天】单点登录(Single Sign-On,SSO)是一种用户认证方式,用户在多个应用系统中只需要登录一次,就可以访问所有相互信任的应用系统。
777 1
|
小程序 前端开发 JavaScript
微信小程序——解决异步问题
微信小程序——解决异步问题
1056 0

热门文章

最新文章