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

相关推荐
木子.李3474 小时前
排序算法总结(C++)
c++·算法·排序算法
闪电麦坤955 小时前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
Gyoku Mint6 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦6 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp6 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法
枫景Maple7 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄7 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄7 小时前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯
小wanga8 小时前
【递归、搜索与回溯】专题三 穷举vs暴搜vs回溯vs剪枝
c++·算法·机器学习·剪枝