题解 | #几步可以从头跳到尾#

几步可以从头跳到尾

https://www.nowcoder.com/practice/de62bcee9f9a4881ac80cce6da42b135

#include <vector>
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 最少需要跳跃几次能跳到末尾
     * @param n int整型 数组A的长度
     * @param A int整型vector 数组A
     * @return int整型
     */
    int Jump(int n, vector<int>& A) {
        // write code here
        int next_maxPosition=0;//设定下一步能跳多远
        int cur_position=0;//设定当前所能跳的最大位置
        int cnt=0;
        for (int i=0; i<A.size(); i++) {
            next_maxPosition=max(A[i]+i,next_maxPosition);//遍历当前所能跳的范围,找出下一步能跳的最大值
            if (i==cur_position) {//已经遍历当前所能跳的范围,该跳到next_maxPosition所指示的范围内
                cur_position=next_maxPosition;
                cnt++;//次数+1
            }
            if (cur_position>=A.size()-1) {
                break;
            }
        }
        return cnt;
    }
};

全部评论

相关推荐

神哥不得了:神哥来啦~ JVm可以写在juc的下面,另外的话,项目亮点的话再重新用star法则再改一遍,其余的东西写的还是非常的好的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务