力扣55. 跳跃游戏

2023-12-23 06:15:43

贪心算法

  • 思路:
    • 当前所在位置 pos,能够到达的最远位置为 pos + nums[pos];
    • 如果最远位置能到达边界即能够跳出圈:
      • if (rightmost >= size - 1) {

        ? ? return true;

        }

    • 在能跳跃范围内(idx <= rightmost)更新能跳最远的位置:
      • rightmost = std::max(rightmost, idx + nums[idx]);

    • 否则,不能跳出圈;
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int size = nums.size();
        int rightmost = 0;
        for (int idx = 0; idx < size; ++idx) {
            if (idx <= rightmost) {
                rightmost = std::max(rightmost, idx + nums[idx]);
                if (rightmost >= size - 1) {
                    return true;
                }
            }
        }

        return false;
    }
};

文章来源:https://blog.csdn.net/N_BenBird/article/details/135163734
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。