【随想录】Day32—第八章 贪心算法 part02

目录

  • [题目1: 买卖股票的最佳时机 II](#题目1: 买卖股票的最佳时机 II)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐买卖股票的最佳时机 II ------题解思路](#⭐买卖股票的最佳时机 II ——题解思路)
  • [题目2: 55. 跳跃游戏](#题目2: 55. 跳跃游戏)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐跳跃游戏 ------题解思路](#⭐跳跃游戏 ——题解思路)
  • [题目3: 45. 跳跃游戏 II](#题目3: 45. 跳跃游戏 II)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐跳跃游戏 II ------题解思路](#⭐跳跃游戏 II ——题解思路)

题目1: 买卖股票的最佳时机 II


1- 思路

贪心:

  • 求数组中相邻两个元素的差值,例如数组 [ 1, 5 , 3 ]
  • 如果是第一天买如,第三天卖出,相当于 p[2] - p[0] = p[2] - p[1] + p[1] - p[0]
  • 贪心思路 :实际上就是求相邻两个元素的差值和,若差值大于 0 则收集结果,为利润,本题贪心即 求 所有正数差值和

2- 题解

⭐买卖股票的最佳时机 II ------题解思路

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int[] sub = new int[prices.length-1];
        int index = 0;
        int res = 0;
        for(int i = 1 ; i < prices.length;i++){
            sub[index++] = prices[i] - prices[i-1];
        }
        for(int i = 0 ; i < sub.length;i++){
            if(sub[i]>0){
                res+=sub[i];
            }
        }
        return res;
    }
}

题目2: 55. 跳跃游戏


1- 思路

贪心

  • 定义一个 int cover变量,代表数组的覆盖范围
  • 通过覆盖范围来遍历数组,每次更新 cover = cover + nums[i],同时覆盖范围取 范围内最大值
  • 贪心思路 :遍历 cover 范围内的数组,每次根据 当前数组的 nums 值,取当前范围最大的可到达数 为当前 cover
    • 如果 cover 超出 数组长度 直接返回 true
    • 否则返回 false

2- 题解

⭐跳跃游戏 ------题解思路

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

        return false;
    }
}

题目3: 45. 跳跃游戏 II


1- 思路

  • 区分于 跳跃游戏的区别在于,并非每次是跳的最大次数就最少

贪心

  • **贪心思路:**以最少的步数,尽可能多的增加覆盖范围 cover ,区别于跳跃游戏基础版的点在于,再定义一个 nextCover,记录每次遍历到的最大范围,但每次不一定更新 cover
    • 只有在当前 cover 走不下去时候,再更新 cover,对结果进行 ++

2- 题解

⭐跳跃游戏 II ------题解思路

java 复制代码
class Solution {
    public int jump(int[] nums) {
        int cover = 0;
        int nextCover = 0;
        int res = 0;
        for(int i = 0 ; i < nums.length;i++){
            nextCover = Math.max(nums[i]+i,nextCover);
            if(i==cover){
                if(cover!=nums.length-1){
                    res++;
                    cover = nextCover;
                }
            }
        }
        return res;
    }
}

相关推荐
CappuccinoRose1 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦1 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav1 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi
小O的算法实验室2 小时前
2026年ESWA,自适应基于排序的协同进化学习粒子群算法+边缘计算服务器部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
cpp_25013 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
꧁细听勿语情꧂3 小时前
合并两个有序表、判断链表的回文结构、相交链表、环的链表一和二
c语言·开发语言·数据结构·算法
木井巳3 小时前
【递归算法】解数独
java·算法·leetcode·决策树·深度优先·剪枝
大肥羊学校懒羊羊4 小时前
完数与盈数的计算题解
数据结构·c++·算法
阿Y加油吧4 小时前
算法实战笔记:LeetCode 31 下一个排列 & 287 寻找重复数
笔记·算法·leetcode
穿条秋裤到处跑4 小时前
每日一道leetcode(2026.04.24):距离原点最远的点
算法·leetcode·职场和发展