LeetCode——贪心算法

贪心思想

保证每次操作都是局部最优的,并且最后得到的结果是全局最优的------减少遍历的次数

1.买卖股票的最佳时机 121简单

这里的贪心思想是更新股票的最低价和最大利润,规则是先买后卖

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        // 记录股票的最低价
        int minPrice = Integer.MAX_VALUE;
        // 记录最大利润
        int maxProfit = 0;
        for (int i = 0; i < prices.length; i++) {
            if (prices[i] < minPrice) {
                minPrice = prices[i];
            } else if (prices[i] - minPrice > maxProfit) {
                maxProfit = prices[i] - minPrice;
            }
        }
        return maxProfit;
    }
}

2. 跳跃游戏 55 中等

这里的贪心是每次跳跃都有多种选择,每次选择跳跃最大的

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int k = 0;
        for (int i = 0; i < nums.length; i++) {
            if (i > k) return false;
            k = Math.max(k, i + nums[i]);
        }
        return true;
    }
}

3. 跳跃游戏 II 45 中等

for循环中的减1是因为跳到最后一个元素位置的时候,此次游戏就已经结束了。这里的贪心是每次跳跃的最大位置如果刚好是i所在的位置,那么需要一次跳跃。

java 复制代码
class Solution {
    public int jump(int[] nums) {
        // 记录每次能iao的最大范围
        int k = 0;
        // 跳到最后一个位置需要跳跃的总次数
        int sum = 0;
        // 能跳到的最远的位置
        int end = 0;
        for (int i = 0; i < nums.length - 1; i++) {
            // if (k >= nums.length - 1) {
            //     break;
            // }
            k = Math.max(k, nums[i] + i);
            if (i == end) {
                end = k;
                sum++;
            }
            System.out.println(k);
         }
        return sum;
    }
}

4. 划分字母区间 763 中等

贪心就是找一个区间内每个字母出现的最后位置,一个区间的结束刚好等于i的时候,说明这个区间结束了,定义start是本题需要返回区间的长度,end和start可以方便计算区间长度,比每次遍历长度+1节省性能。

java 复制代码
class Solution {
    public List<Integer> partitionLabels(String s) {
        // 遍历一次数组,找到每个字母最后一次的下标
        int[] last = new int[26];
        int sLength = s.length();
        for (int i = 0; i < sLength; i++) {
            last[s.charAt(i) - 'a'] = i;
        }
        // 遍历数组,更新max,如果i==max,说明可以在这个位置分割字符串了
        // 存储结果的序列
        List<Integer> partition = new ArrayList<Integer>();
        int start = 0;
        int end = 0;
        for (int i = 0; i < sLength; i++) {
            end = Math.max(end, last[s.charAt(i) - 'a']);
            if (end == i) {
                partition.add(end - start + 1);
                start = end + 1;
            }
        }
        return partition;
    }
}
相关推荐
WolfGang0073215 分钟前
代码随想录算法训练营 Day39 | 动态规划 part12
算法·动态规划
阿Y加油吧17 分钟前
动态规划经典题解:最长递增子序列 & 乘积最大子数组
算法·动态规划·代理模式
f3iiish25 分钟前
3783. 整数的镜像距离 力扣
算法·leetcode
Not Dr.Wang42228 分钟前
基于matlab的控制系统奈氏图及其稳定性分析
数据结构·算法·matlab
闻缺陷则喜何志丹40 分钟前
【排序 离散化 二维前缀和】 P7149 [USACO20DEC] Rectangular Pasture S|普及+
c++·算法·排序·离散化·二维前缀和
rainbow72424444 分钟前
AI学习路线分享:通用型认证与算法认证学习体验对比
人工智能·学习·算法
君义_noip1 小时前
信息学奥赛一本通 4163:【GESP2512七级】城市规划 | 洛谷 P14921 [GESP202512 七级] 城市规划
c++·算法·图论·gesp·信息学奥赛
Simon_lca1 小时前
验厂不翻车!Acushnet 11 项核心政策 + 自查要点,一文搞定
大数据·人工智能·经验分享·算法·制造
智者知已应修善业1 小时前
【51单片机按键控制流水灯+数码管显示按键次数】2023-6-15
c++·经验分享·笔记·算法·51单片机
汉克老师1 小时前
GESP2023年12月认证C++三级( 第三部分编程题(1、小猫分鱼))
c++·算法·模拟算法·枚举算法·gesp三级·gesp3级