集美大学-计算机打卡(19)

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最好或最优的算法策略。在解决能否到达终点以及最小步数的问题中,贪心算法常常能够提供简单而高效的解决方案。

 //当前的覆盖最大区域
        int curDistance = 0;
        //最大的覆盖区域
        int maxDistance = 0;
        for (int i = 0; i < nums.length; i++) {
            //在可覆盖区域内更新最大的覆盖区域
            maxDistance = Math.max(maxDistance,i+nums[i]);
            //说明当前一步,再跳一步就到达了末尾
            if (maxDistance>=nums.length-1){
                count++;
                break;
            }
            //走到当前覆盖的最大区域时,更新下一步可达的最大区域
            if (i==curDistance){
                curDistance = maxDistance;
                count++;
            }
        }
        return count;
    }

这段代码片段是一个典型的贪心算法应用,用于解决跳跃游戏中的问题。具体来说,代码通过遍历数组中的每一个位置,维护当前可达的最大区域,然后在当前覆盖的最大区域内选择下一步的位置。通过这种方式,算法在每一步都选择最有利的位置,从而达到能否到达终点以及最小步数的目的。

总体思路如下:

1. 维护两个变量 `curDistance` 和 `maxDistance`,分别表示当前覆盖的最大区域和全局最大的覆盖区域。

2. 遍历数组,更新 `maxDistance` 为当前位置能够覆盖的最大范围。

3. 如果 `maxDistance` 大于等于数组的长度减一,说明已经可以到达终点,此时退出循环。

4. 在当前覆盖的最大区域内选择下一步的位置,更新 `curDistance` 为 `maxDistance`,并增加步数 `count`。

5. 重复以上步骤直到到达终点。

这样,算法保证每一步都选择了当前最有利的位置,从而达到了能否到达终点以及最小步数的要求。这种贪心策略的优势在于简单易懂且高效,适用于一些特定的问题场景。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值