LeetCode.55 跳跃游戏

本文介绍了解决LeetCode上跳跃游戏问题的一种方法:通过贪心策略来判断能否从起始位置到达最后一个位置。核心思路是计算当前位置所能达到的最远距离,以此决定下一步的跳跃位置。

原题

https://leetcode-cn.com/problems/jump-game/

在这里插入图片描述
思路
贪心策略,找出当前位置能走的最远距离(当前步跨越距离+下一步可走最大距离)

题解

package com.leetcode.code;

/**
 * @ClassName Code55
 * @Author ZK
 * @Description
 * @Date 2021/2/3 11:04
 * @Version 1.0
 **/
public class Code55 {

    public static void main(String[] args) {
        int[] nums = {0,1};
        System.out.println(canJump(nums));
    }

    public static boolean canJump(int[] nums) {
        int len = nums.length;

        for (int i = 0; i < len; ) {
//            如果当前位置已经到数组的最后了,则直接返回true
            if (i >= len-1) {
                return true;
            } else {
//                如果当前位置为0,则无法跳跃,自然不能到达终点
                if (nums[i] == 0) {
                    return false;
                } else {
//                    确定下一步走到哪里,也就是迭代变量i下一次的值
                    i = max(nums, i+1, i+nums[i]);
                }
            }
        }
//        其实这个return,应该永远走不到
        return true;
    }

    /**
     * 给定一个位置区间,确定当前下一步走到当前区间的哪个位置
     * @param nums      原始数组
     * @param begin     开始位置
     * @param end       终点位置
     * @return
     */
    public static int max(int[] nums, int begin, int end){
        int len = nums.length;
//        如果终点位置已经在数组的最后了,直接返回最后位置
        if (end >= len-1) {
            return end;
        }
//        先将结果设为开始begin的位置
        int res = begin;
//        从开始begin的下一个位置开始遍历,遍历到结束end的位置
        for (int i = begin+1; i <= end; i++) {
//            获取一个 (当前距离+下一步可走距离)的最大值,i即是当前应该走到的位置
            if ( (i+nums[i]) >= (res+nums[res]) ) {
                res = i;
            }
        }
        return res;
    }

}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

难过的风景

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值