【随想录】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;
    }
}

相关推荐
M__332 分钟前
动态规划进阶:简单多状态模型
c++·算法·动态规划
未来之窗软件服务5 分钟前
计算机等级考试—Dijkstra(戴克斯特拉)& Kruskal(克鲁斯卡尔)—东方仙盟
算法·计算机软考·仙盟创梦ide·东方仙盟
Hcoco_me8 分钟前
大模型面试题89:GPU的内存结构是什么样的?
人工智能·算法·机器学习·chatgpt·机器人
N.D.A.K14 分钟前
CF2138C-Maple and Tree Beauty
c++·算法
im_AMBER23 分钟前
Leetcode 104 两两交换链表中的节点
笔记·学习·算法·leetcode
程序员-King.28 分钟前
day159—动态规划—打家劫舍(LeetCode-198)
c++·算法·leetcode·深度优先·回溯·递归
小雨下雨的雨30 分钟前
禅息:在鸿蒙与 Flutter 之间寻找呼吸的艺术
算法·flutter·华为·重构·交互·harmonyos
浅念-31 分钟前
C语言——单链表
c语言·开发语言·数据结构·经验分享·笔记·算法·leetcode
hans汉斯37 分钟前
建模与仿真|基于GWO-BP的晶圆机器人大臂疲劳寿命研究
大数据·数据结构·算法·yolo·机器人·云计算·汉斯出版社
wazmlp00188736938 分钟前
python第一次作业
开发语言·python·算法