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

相关推荐
小白菜又菜15 分钟前
Leetcode 3432. Count Partitions with Even Sum Difference
算法·leetcode
wuhen_n1 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
sin_hielo1 小时前
leetcode 2483
数据结构·算法·leetcode
Xの哲學2 小时前
Linux多级时间轮:高精度定时器的艺术与科学
linux·服务器·网络·算法·边缘计算
大头流矢2 小时前
归并排序与计数排序详解
数据结构·算法·排序算法
油泼辣子多加3 小时前
【信创】算法开发适配
人工智能·深度学习·算法·机器学习
Aaron15883 小时前
AD9084和Versal RF系列具体应用案例对比分析
嵌入式硬件·算法·fpga开发·硬件架构·硬件工程·信号处理·基带工程
laocooon5238578863 小时前
插入法排序 python
开发语言·python·算法
wuhen_n4 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
林shir5 小时前
Java基础1.7-数组
java·算法