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

T121:买卖股票最佳时机

题目要求:给定一个数组 prices ,它的第 i 个元素 pricesi 表示一支给定股票第 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。

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

0 <= j <= numsi 且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,就代表了到达终点

相关推荐
To_OC11 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵15 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC17 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
金銀銅鐵1 天前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法