首页 > 其他 > 详细

Min Cost Climbing Stairs - LeetCode

时间:2019-02-13 16:25:50      阅读:181      评论:0      收藏:0      [点我收藏+]

题目链接

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])

Min Cost Climbing Stairs - LeetCode

原文:https://www.cnblogs.com/multhree/p/10370164.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!