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

必会知识

相关推荐
亦暖筑序20 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6751 天前
字节跳动国际支付-后端开发-三面面经
java
Flittly1 天前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
RainCity1 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl