LeetCode - 121 买卖股票的最佳时机
LeetCode 股票 买卖 最佳时机 121
2023-09-14 09:04:04 时间
目录
题目来源
题目描述
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。
你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。
返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。
示例
输入 | [7,1,5,3,6,4] |
输出 | 5 |
说明 | 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。 注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。 |
输入 | prices = [7,6,4,3,1] |
输出 | 0 |
说明 | 在这种情况下, 没有交易完成, 所以最大利润为 0。 |
提示
1 <= prices.length <= 105
0 <= prices[i] <= 104
题目解析
本题其实可以用滑动窗口的思维去思考,
我们用一个指针 i 遍历prices数组(for循环),如果i指针指向的prices元素是0~i范围内最小值,则作为滑动窗口左边界,然后i指针继续向右遍历,
- 如果没有遇到比滑动窗口左边界更小的元素,则都当成滑动窗口右边界的值,因此我们统计出每个右边界与左边界的插值diff,并只保留最大的diff。
- 如果遇到了比滑动窗口左边界更小的元素,则更新滑动窗口的左边界,然后继续前面逻辑
下面算法代码中,min值就是滑动窗口左边界的值,每一个prices[i]都可以当成滑动窗口右边界的值,diff是滑动窗口右边界和左边界的插值,我们只保留最大的diff作为题解。
算法源码
/**
* @param {number[]} prices
* @return {number}
*/
var maxProfit = function(prices) {
let min = prices[0]
let diff = 0
for(let i=1; i<prices.length; i++) {
if(prices[i] < min) {
min = prices[i]
} else {
diff = Math.max(diff, prices[i]-min)
}
}
return diff
};
相关文章
- leetcode 2. 两数相加 js 实现
- LeetCode买卖股票之一:基本套路(122)
- ☆打卡算法☆LeetCode 221. 最大正方形 算法解析
- LeetCode周赛298,阳光普照,参加就能简历免筛
- leetcode 141. 环形链表 js 实现
- LeetCode 121. 买卖股票的最佳时机
- LeetCode 657. 机器人能否返回原点
- leetcode 20. 有效的括号 js实现
- 最大正方形(leetcode 221)
- JavaScript刷LeetCode拿offer-js版字典
- 前端工程师leetcode算法面试必备-简单的二叉树
- LeetCode 82:删除排序链表中的重复元素 II
- leetcode 11. 盛最多水的容器 js实现
- LeetCode 312.戳气球
- 【算法】动态规划 ⑤ ( LeetCode 63.不同路径 II | 问题分析 | 动态规划算法设计 | 代码示例 )
- C 语言的 LeetCode 30 天挑战 第2部分,共10部分