力扣题目汇总 使用贪心算法解决问题

贪心算法是一种通过局部最优解来获得全局最优解的算法。它的核心思想是:在每一步中选择当前看起来最优的解,并希望通过一系列局部最优选择最终得到全局最优解。

121.买卖股票的最佳时机

分析:

在每一天求出当前最优的利润,也就是我当天卖出,我要想获得最大利润就是找到最低买入价。然后从每个局部最优解里面选出全局最优解。

解决:
java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int result=0;
        int minPrice=prices[0];
        for (int i=1;i<prices.length;i++){
            result=Math.max(prices[i]-minPrice,result);
            minPrice=Math.min(minPrice,prices[i]);
        }
        return result;
    }
}

55.跳跃游戏

分析

每次选择当前能跳跃的最远距离,从而尽可能地扩展到达范围。从一个位置跳到下一个位置,看看当前位置是否可达,如果可达,就看看从当前位置能跳跃的最远距离,不断更新maxReach扩展最大到达距离,如果最大到达距离maxReach>=size-1了,就返回true

解决
java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int maxReach=0;
        int n=nums.length;
        for (int i=0;i<n;i++){
            if (i<=maxReach){
                maxReach=Math.max(i+nums[i],maxReach);
                if (maxReach>=n-1){
                    return true;
                }
            }else{
                return false;
            }
        }
        return false;
    }
}
相关推荐
共享家952728 分钟前
顺序表的C语言实现与解析
数据结构·算法
uhakadotcom1 小时前
英伟达最新的GTC 2025提供了哪些新技术新能力?
算法·面试·github
ChoSeitaku2 小时前
NO.42十六届蓝桥杯备战|数据结构|算法|时间复杂度|空间复杂度|STL(C++)
数据结构·算法·蓝桥杯
努力学习的小廉3 小时前
我爱学算法之——滑动窗口攻克子数组和子串难题(上)
开发语言·c++·算法
梦想攻城狮3 小时前
深度学习之神经网络
人工智能·算法·机器学习
阿巴~阿巴~4 小时前
素数判定方法详解:从基础试除法到优化策略
c++·算法
Vitalia4 小时前
图论入门【数据结构基础】:什么是树?如何表示树?
数据结构·算法·图论·
埃菲尔铁塔_CV算法4 小时前
WPF 开发从入门到进阶(五)
深度学习·算法·机器学习·计算机视觉·wpf
Cindy辛蒂4 小时前
C语言:能够规定次数,处理非法字符的猜数游戏(三重循环)
c语言·算法·游戏
小卡皮巴拉5 小时前
【力扣刷题实战】无重复的最长字串
开发语言·c++·算法·leetcode·滑动窗口