zoukankan      html  css  js  c++  java
  • Min Cost Climbing Stairs

    题目链接

    Min Cost Climbing Stairs - LeetCode

    注意点

    • 注意边界条件

    解法

    解法一:这道题也是一道dp题。dp[i]表示爬到第i层的最小cost,想要到达第i层只有两种可能性,一个是从第i-2层上直接跳上来,一个是从第i-1层上跳上来。所以可以得到dp[i] = min(dp[i- 2] + cost[i - 2], dp[i - 1] + cost[i - 1])。时间复杂度O(n)。

    class Solution {
    public:
        int minCostClimbingStairs(vector<int>& cost) {
            int n = cost.size(),i;
            vector<int> dp(n+1, 0);
            for(i = 2;i <= n;i++)
            {
                dp[i] = min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
            }
            return dp[n];
        }
    };
    

    解法二:换一个思路。我们离开这一层一定要花费cost[i],到达这一层我们还是要从前一层或者前两层的台阶上跳上来,所以得到dp[i] = cost[i] + min(dp[i- 1], dp[i - 2]),最后我们在最后两个dp值中选择一个较小的返回即可。时间复杂度O(n)。

    class Solution {
    public:
        int minCostClimbingStairs(vector<int>& cost) {
            int n = cost.size(),i;
            vector<int> dp(n,0);
            dp[0] = cost[0];
            dp[1] = cost[1];
            for(i = 2;i < n;i++)
            {
                dp[i] = cost[i] + min(dp[i-1],dp[i-2]);
            }
            return min(dp[n-1],dp[n-2]);
        }
    };
    

    小结

    • 这道题可以扩展到每次可以走k步,那解法一递推式就变为dp[i] = min(dp[i - k]+cost[i - k],...,dp[i- 2] + cost[i - 2], dp[i - 1] + cost[i - 1])。解法二递推式变为dp[i] = cost[i] + min(dp[i- 1], dp[i - 2],...,dp[i - k])
  • 相关阅读:
    程序猿编程,软件设计都干什么?
    工作流——来龙去脉
    开发编码流程
    我的spring-boot开发环境
    JSR 303
    项目中java异常处理
    学习交流,一些数据结构和算法实现!
    C运算符
    js锚点
    玻璃工艺学笔记
  • 原文地址:https://www.cnblogs.com/multhree/p/10370164.html
Copyright © 2011-2022 走看看