题解 | #牛牛的跳跃挑战#

牛牛的跳跃挑战

https://www.nowcoder.com/practice/0c99c2161c2d4a4e91ca55363cc0e059

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param height int整型vector
     * @return int整型
     */
    int minEnergyJump(vector<int>& height) {
        // write code here
        int n = height.size();
        int dp[10010];
        for (int i = 3; i <= n; ++i) {
            dp[i] = min(dp[i - 1] + height[i - 1], min(dp[i - 2] + height[i - 2], dp[i - 3] + height[i - 3]));
        }
        return dp[n];
    }
};

一、题目考察的知识点

dp

二、题目解答方法的文字分析

每次只能跨三个以下,依次遍历,计算每次跨后的最小。

三、本题解析所用的编程语言

c++

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务