海智算法训练营第三十一天 | 第八章 贪心算法 part02 | ● 122.买卖股票的最佳时机II ● 55. 跳跃游戏 ● 45.跳跃游戏II

今日任务:

1.利用贪心解决每天利润问题

2.利用贪心覆盖范围解决跳跃问题

3.利用贪心覆盖范围解决跳跃II问题

1.利用贪心解决每天利润问题

力扣题目链接

这道题可以用贪心很简单的做出来,从图中可以发现,其实我们需要收集每天的正利润就可以,收集正利润的区间,就是股票买卖的区间,而我们只需要关注最终利润,不需要记录区间

复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int sum = 0;
        for (int i = 1; i < prices.length; i++) {
            sum += prices[i] - prices[i-1] > 0 ? prices[i] - prices[i-1] : 0;
        }
        return sum;
    }
}

所以代码实现起来也非常的简单

2.利用贪心覆盖范围解决跳跃问题

力扣题目链接

贪心算法局部最优解:每次取最大跳跃步数(取最大覆盖范围),整体最优解:最后得到整体最大覆盖范围,看是否能到终点。不一定非要明确一次究竟跳几步,每次取最大的跳跃步数,这个就是可以跳跃的覆盖范围。

复制代码
class Solution {
    public boolean canJump(int[] nums) {
        if(nums.length == 1)    return true;
        int cover = 0;
        for (int i = 0; i <= cover; i++) {
            if(cover >= nums.length - 1)    return true;
            cover = Math.max(i + nums[i] , cover);
        }
        return false;
    }
}

3.利用贪心覆盖范围解决跳跃II问题

力扣题目链接

这道跳跃II的问题和跳跃I的问题区别就在于前者是寻找最短的跳跃次数,而解题的关键就在于每次跳跃的区间内去寻找下一个跳跃的最大区间,直到到达终点,代码的实现呢需要有两个指针,cur指针用来指向当前的跳跃前的位置,next指针用来计算下次跳跃的最大距离(区间内跳的最远的距离)。

复制代码
class Solution {
    public int jump(int[] nums) {
        int cur = 0 , next = 0 , res = 0;
        for (int i = 0; i < nums.length; i++) {
            next = Math.max(next , nums[i] + i);
            if(i == cur){
                if(i < nums.length-1){
                    res++;
                    cur = next;
                    if(cur >= nums.length-1)    break;
                }else break;
            }
        }
        return res;
    }
}

学习时长:2h

总结:这次学习接触了较简单的贪心算法题,对贪心算法有了初步的理解。

相关推荐
云栖梦泽在4 分钟前
AI安全入门:AI模型泄露的风险与防护措施
人工智能·算法·动态规划
水木流年追梦17 分钟前
大模型入门-应用篇3-Agent智能体
开发语言·python·算法·leetcode·正则表达式
洛水水27 分钟前
【力扣100题】31.二叉树的层序遍历
算法·leetcode·职场和发展
君义_noip33 分钟前
CSP-S 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·初赛·csp 第一轮
洛水水36 分钟前
【力扣100题】41.爬楼梯
算法·leetcode·职场和发展
Pkmer1 小时前
LeetCode 上极少见的工程级滑窗实现
python·leetcode
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2026.05.13 题目:1674. 使数组互补的最少操作次数
笔记·算法·leetcode
liulilittle2 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
每天回答3个问题2 小时前
LeetCodeHot100|回溯算法、46.全排列、78.子集、17.电话号码的字母组合
算法·深度优先·回溯
YL200404262 小时前
038翻转二叉树
数据结构·leetcode