【LeetCodehot100】:贪心算法:T121:买卖股票最佳时机 T55:跳跃游戏 T45:跳跃游戏2

T121:买卖股票最佳时机

题目要求:给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。

核心思路

  1. 遍历数组
  2. 更新最低价
  3. 计算当前利润
  4. 更新最大差价

代码实现

java 复制代码
int minPrice=Integer.MAX_VALUE;
int maxProfit=0;

for(int price:prices){
//1.获取最小价
minPrice=Math.min(minPrice,price);
//2.计算差价
int profit=price-minPrice;
//3.更新最大利润
maxProfit=Math.max(maxProfit,profit);
}
return maxProfit;

总结

记住思路

  1. 遍历数组
  2. 更新最低价
  3. 计算当前利润
  4. 更新最大差价

T55:跳跃游戏

题目要求:给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。

题目本质

我们不需要知道具体是怎么跳的,我们只需要知道

我当前最远能跳到哪

核心思路

1.定义一个最远距离:maxReach

用来记录当前最远能达到哪里

2.遍历数组

先更新最远记录maxReach

再判断是否(i>maxReach)

代码实现

java 复制代码
int maxReach=0;

for(int i=0;i<nums.length;i++){
if(i>maxReach){
return false;
}
maxReach=Math.max(maxReach,i+nums[i]);
}
return true;

总结

本质:记录最远能达到是位置是哪,然后根据最远微位置判断是否能达到末尾

T45:跳跃游戏2

题目要求:

给定一个长度为 n 的 0 索引整数数组 nums。初始位置在下标 0。

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在索引 i 处,你可以跳转到任意 (i + j) 处:

0 <= j <= nums[i] 且i + j < n

返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 n - 1。

核心思路

我们需要三个变量

end:当前这一跳的边界(这一步最多到哪)

maxReach:下一步最远能到哪

steps:步数

1.遍历数组:获取第一跳能包含的范围,在这个范围中找出最大能跳到哪

2.在第一跳的范围中更新最远能达到哪里。知道遍历到(i==end)时,开启第二跳,此时step++;end=maxReach

代码实现

java 复制代码
int end=0;
int maxReach=0;
int step=0;

for(int i=0;i<nums.length-1;i++){
maxReach=Math.max(maxReach,i+nums[i]);

if(i==end){
step++;
end=maxReach;
}
return step;
}

总结

理解核心思路,本题创新点在于maxReach的大小,我们要遍历第一轮跳中所有的maxReach,才是正真的max。当i==end时,代表了要开启下一轮跳,同步更新step,当end=maxReach,就代表了到达终点

相关推荐
旖-旎1 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM2 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮2 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮3 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程
橙淮3 小时前
双指针法:高效算法解题的利器
算法
初心未改HD3 小时前
深度学习之MLP与反向传播算法详解
人工智能·深度学习·算法
刀法如飞3 小时前
【Go 字符串查找的 20 种实现方式,用不同思路解决问题】
人工智能·算法·go
谙弆悕博士3 小时前
【附C++源码】从零开始实现 2048 游戏
java·c++·游戏·源码·项目实战·2048
沃普天科技3 小时前
TYPE C全功能10G数据放大延长PS8353 PS8780 PS8778 8K60HZ
驱动开发·游戏·计算机外设·电脑·ar·硬件工程·vr