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])
  • 相关阅读:
    java第九次作业
    java第八次作业
    java第七次作业
    java第六次作业
    java第五次作业
    java第四次作业
    java第三次作业
    java第二次作业
    java第一次作业
    Javascript设计模式-----装饰者模式
  • 原文地址:https://www.cnblogs.com/multhree/p/10370164.html
Copyright © 2011-2022 走看看