【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,就代表了到达终点

相关推荐
FakeOccupational16 小时前
【数学 密码学】量子通信:光的偏振&极化的量子不确定性特性 + 量子密钥分发 BB84算法步骤
算法·密码学
ZhengEnCi18 小时前
S10-蓝桥杯 17822 乐乐的积木塔
算法
贾斯汀玛尔斯18 小时前
每天学一个算法--拓扑排序(Topological Sort)
算法·深度优先
大龄程序员狗哥18 小时前
第25篇:Q-Learning算法解析——强化学习中的经典“价值”学习(原理解析)
人工智能·学习·算法
exp_add318 小时前
质数相关知识
算法
小辉同志19 小时前
215. 数组中的第K个最大元素
数据结构·算法·leetcode··快速选择
小O的算法实验室19 小时前
2025年IEEE TITS,基于矩阵的进化计算+面向无线传感器网络数据收集无人机路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
OidEncoder19 小时前
编码器分辨率与机械精度的关系
人工智能·算法·机器人·自动化
memcpy019 小时前
LeetCode 2615. 等值距离和【相同元素分组+前缀和;考虑距离和的增量】中等
算法·leetcode·职场和发展
炽烈小老头20 小时前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法