408算法题leetcode--第34天

746. 使用最小花费爬楼梯

题目地址746. 使用最小花费爬楼梯 - 力扣(LeetCode)

题解思路:dp

时间复杂度:O(n)

空间复杂度:O(n)

代码:

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        // dp[]: 爬到i位置的总最小费用
        // 转移:dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
        // 初始化:dp[0, 1] = 0
        // 顺序:前到后
        int size = cost.size();
        vector<int>dp(size + 1, 0);
        dp[0] = 0;
        dp[1] = 0;
        for(int i = 2; i <= size; i++){
            dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
        }
        return dp[size];
    }
};

62. 不同路径

题目地址62. 不同路径 - 力扣(LeetCode)

题解思路:dp

时间复杂度:O(m * n)

空间复杂度:O(m * n)

代码:

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        // dp[][]: 该位置有多少种走法
        // 转移:dp[i][j] = dp[i - 1][j] + dp[i][j - 1]
        // 初始化:第一行和第一列为1
        // 顺序:从左到右,从上到下;可以用滚动数组优化为dp[]
        vector<vector<int>>dp(m, vector<int>(n, 0));
        for(int i = 0; i < m; i++) dp[i][0] = 1;
        for(int j = 0; j < n; j++) dp[0][j] = 1;
        for(int i = 1; i < m; i++){
            for(int j = 1; j < n; j++){
                dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
            }
        }
        return dp[m -1][n - 1];
    }
};
相关推荐
java干货4 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
皮皮哎哟12 分钟前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒21 分钟前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
vortex535 分钟前
几种 dump hash 方式对比分析
算法·哈希算法
Wei&Yan2 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
团子的二进制世界2 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨2 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3162 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
近津薪荼2 小时前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先