当前位置: 首页 > article >正文

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

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

121.买卖股票的最佳时机

分析:

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

解决:
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

解决
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;
    }
}

http://www.kler.cn/a/590799.html

相关文章:

  • 热更新解决方案5——toLua
  • TCP 客户端 - 服务器通信程序搭建
  • ora-600 ktugct: corruption detected---惜分飞
  • 晶艺代理,100V3.5A高耐压LA1823完全替换MP9487--启烨科技有限公司
  • 每天五分钟深度学习框架pytorch:基于pytorch搭建循环神经网络RNN
  • 【大模型基础_毛玉仁】3.1 Prompt 工程简介
  • 清晰易懂的Node.js安装教程
  • 【Git学习笔记】Git分支管理策略及其结构原理分析
  • 操作系统的心脏节拍:CPU中断如何驱动内核运转?
  • Conda 环境迁移指南
  • dataframe数据形式操作中的diff和shift函数区别与对比
  • [Lc15_bfs+floodfill] 图像渲染 | 岛屿数量 | 岛屿的最大面积 | 被围绕的区域
  • 使用 ESP8266 和 Android 应用程序实现基于 IOT 的语音控制家庭自动化
  • 从字段级脱敏到文件级授权,构建全场景数据安全闭环
  • Linux与HTTP报头属性和请求方式
  • flutter 专题 八十八 Flutter原生混合开发
  • 常见限流算法及实现
  • 蓝桥杯嵌入式组第十四届省赛题目解析+STM32G431RBT6实现源码
  • 【一起来学kubernetes】17、Configmap使用详解
  • 程序包jakarta.annotation不存在