【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个字母,先记录每个字母最后出现的位置。

必会知识

相关推荐
老星*6 分钟前
AI选股核心设计思路
java·ai·开源·软件开发
invicinble13 分钟前
spirng的bean的生命周期,以及为什么这么设计
spring
小O的算法实验室14 分钟前
2025年IEEE TITS,基于矩阵的进化计算+面向无线传感器网络数据收集无人机路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
kongba00716 分钟前
项目打包 Python Flask 项目发布与打包专家 提示词V1.0
开发语言·python·flask
OidEncoder23 分钟前
编码器分辨率与机械精度的关系
人工智能·算法·机器人·自动化
それども25 分钟前
Comparator.comparing 和 拆箱问题
java·jvm
froginwe1131 分钟前
C 语言测验
开发语言
memcpy034 分钟前
LeetCode 2615. 等值距离和【相同元素分组+前缀和;考虑距离和的增量】中等
算法·leetcode·职场和发展
今夕资源网1 小时前
powershell工具包 安装升级脚本并设置UTF-8 环境快捷方式创建 将powershell的编码默认改为UTF-8
开发语言·utf-8·powershell·utf-8编码·powershell7·powershell5·设置utf-8编码
炽烈小老头1 小时前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法