【JAVA算法|hot100】贪心算法类型题目详解笔记

这里记录刷hot100的思考过程详解,方便后续记忆复习。

贪心算法基本没什么模板,关键在于思考怎样让局部最优扩散到全局最优。一般会有一个max值存储当前所能够到的最远/最大位置

题号121

121. 买卖股票的最佳时机

给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0

具体题解
java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int ans=0;
        int min=Integer.MAX_VALUE,max=Integer.MIN_VALUE;
        for(int i=0;i<prices.length;i++){
            if(prices[i]<min){
                min=prices[i];
            }
            ans=Math.max(prices[i]-min,ans);
        }
        return ans;
    }
}
思路解析

遍历prices,每次只卖目前以来最小的。

必会知识

题号55

55. 跳跃游戏

给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false

具体题解
java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int step=0,tmp=0;
        for(int i=0;i<=tmp&&i<nums.length-1;i++){
            step=Math.max(step,nums[i]+i);
            tmp=step;
        }
        if(step>=nums.length-1){
            return true;
        }
        return false;
    }
}
思路解析

用step保存能跳的最远的值,对其实时更新。

必会知识

题号45

45. 跳跃游戏 II

给定一个长度为 n0 索引 整数数组 nums。初始位置在下标 0。

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在索引 i 处,你可以跳转到任意 (i + j) 处:

  • 0 <= j <= nums[i]
  • i + j < n

返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 n - 1

具体题解
java 复制代码
class Solution {
    public int jump(int[] nums) {
        int rightmost=0,step=0,end=0;
        for(int i=0;i<nums.length-1;i++){
               rightmost=Math.max(rightmost,i+nums[i]);
               if(i==end){
                end=rightmost;
                step++;
           }
        }
        return step;
    }
}
思路解析

每次都记录跳的最远的位置,只有当当前遍历的下标到了上一次确定的最远位置时step才会加一

必会知识

题号763

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。例如,字符串 "ababcc" 能够被分为 ["abab", "cc"],但类似 ["aba", "bcc"]["ab", "ab", "cc"] 的划分是非法的。

注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s

返回一个表示每个字符串片段的长度的列表。

具体题解
java 复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        List<Integer> ans=new ArrayList<>();
        int[] last=new int[26];
        int start=0,end=0;
        for(int i=0;i<s.length();i++){
            last[s.charAt(i)-'a']=i;
        }
        for(int i=0;i<s.length();i++){
            end=Math.max(end,last[s.charAt(i)-'a']);
            if(end==i){
                ans.add(end-start+1);
                start=end+1;
            }
        }
        return ans;
    }
}
思路解析

用数组下标存储26个字母,先记录每个字母最后出现的位置。

必会知识

相关推荐
语戚1 小时前
深入浅出 AOP:织入时机、JDK 动态代理与 CGLIB 原理及 Spring 选择策略
java·开发语言·spring·jdk·代理模式·aop·动态代理
xh didida1 小时前
数据结构--队列
数据结构·算法
啦啦啦_99991 小时前
9. AI面试题之 功能代码实现
java·人工智能
bubiyoushang8881 小时前
基于MATLAB的可见光通信(VLC)发射端:电-光转换与LED驱动仿真
开发语言·matlab
vx-程序开发1 小时前
springboot具备推荐和预警机制的大学生兼职平台的设计与实现-计算机毕业设计源码17157
java·c++·spring boot·python·spring·django·php
子夜江寒1 小时前
YOLO目标检测算法简介
算法·yolo·目标检测
伍一512 小时前
星云ERP免编译安装包分享,可直接运行,附完整程序包下载地址
java
逆境不可逃2 小时前
LeetCode 热题 100 之 279. 完全平方数 322. 零钱兑换 139. 单词拆分 300. 最长递增子序列
java·算法·leetcode·职场和发展
shamalee2 小时前
Spring Security 新版本配置
java·后端·spring