【LeetCode】5. 贪心算法:买卖股票时机

news/2025/2/5 10:50:54/

太久没更了,抽空学习下。

看一道简单题。

在这里插入图片描述

class Solution:def maxProfit(self, prices: List[int]) -> int:cost = -1profit = 0for i in prices:if cost == -1:cost = icontinueprofit_ = i - costif profit_ > profit:profit = profit_if cost  > i:cost = ireturn profit

📌 解题思路:算法>贪心算法

🔹 什么是算法>贪心算法

算法>贪心算法(Greedy Algorithm 的核心思想是:

在每一步都做出当前最优的选择(局部最优),最终得到全局最优解。

在这道题中,我们的目标是在最低点买入,并在未来的某一天卖出,以获得最大利润。

局部最优解:在遍历数组 prices 时,始终记录当前的最低买入价格 cost,并尝试计算最大利润 profit。

全局最优解:整个遍历过程中,确保 profit 始终是所有可能利润中的最大值。

🔹 变量说明

cost:存储最低买入价格,初始为 prices[0](第一天的价格)。

profit:存储最大利润,初始为 0(默认没有利润)。

🔹 遍历 prices 数组的过程

更新最低买入价格 cost

cost = min(cost, i)

遍历过程中,如果发现更低的股票价格 i,就更新 cost,保证买入价始终是历史最低价。

计算并更新最大利润 profit

profit = max(profit, i - cost)

计算当前价格 i 和 cost 之间的利润。

如果利润 i - cost 比之前记录的 profit 更大,就更新 profit。

📌 复杂度分析

时间复杂度:O(n),其中 n 是 prices 的长度。

只遍历一次数组,每次操作 O(1)。

空间复杂度:O(1)。

只使用了 cost 和 profit 两个变量,没有额外的数据结构。

📌 结论:算法>贪心算法的适用性

为什么这道题可以用算法>贪心算法

题目保证只能买卖一次,所以我们只需关注最低买入价格和最大利润,不需要回溯。

每一步都在做局部最优决策(维护最小买入价,计算最大利润),最终得到了全局最优解。

由于股票价格不能回退,过去的最优选择不会影响未来的决策,所以算法>贪心算法是合适的。

⚠️ 什么时候不能用贪心?

如果题目允许多次买卖(比如 122. 买卖股票的最佳时机 II),算法>贪心算法可能不是最佳选择,因为需要考虑交易次数和冷却期等限制,此时可能需要动态规划(DP)。

📌 总结

✅ 这道题可以使用算法>贪心算法,因为每一步的局部最优(最低买入价 & 最大利润)最终导向了全局最优解。
✅ 时间复杂度 O(n),空间复杂度 O(1),是非常高效的解法。
✅ 代码逻辑清晰,适用于类似的一次交易股票买卖问题。


http://www.ppmy.cn/news/1569491.html

相关文章

前端开发中的“原生模块化”——深入解析ES模块(ESM)的使用与优化

随着前端开发技术的不断演进,模块化的概念已不再是新鲜话题。然而,前端开发者仍然面临如何选择和使用模块化工具和规范的问题。近年来,ES模块(ESM,ECMAScript Modules)作为一种原生支持的模块化机制&#x…

C++ Primer 迭代器

欢迎阅读我的 【CPrimer】专栏 专栏简介:本专栏主要面向C初学者,解释C的一些基本概念和基础语言特性,涉及C标准库的用法,面向对象特性,泛型特性高级用法。通过使用标准库中定义的抽象设施,使你更加适应高级…

提升开发效率:IDE使用技巧与插件推荐

在软件开发过程中,选择一个合适的集成开发环境(IDE)并掌握其使用技巧,可以显著提高开发效率。本文将分享一些常用的IDE使用技巧,并推荐几款实用的插件,帮助开发者更好地利用IDE进行开发。 一、IDE使用技巧…

Kafka中文文档

文章来源:https://kafka.cadn.net.cn 什么是事件流式处理? 事件流是人体中枢神经系统的数字等价物。它是 为“永远在线”的世界奠定技术基础,在这个世界里,企业越来越多地使用软件定义 和 automated,而软件的用户更…

MySQL数据库(五)索引

MySQL索引是一种数据结构,它能够帮助数据库系统快速定位到表中的特定记录,从而显著提高查询效率。索引可以被看作是书的目录,通过它可以迅速找到所需的信息而不需要逐页翻阅整本书。以下是对MySQL索引相关的内容介绍: 索引类型 …

实验六 项目二 简易信号发生器的设计与实现 (HEU)

声明:代码部分使用了AI工具 实验六 综合考核 Quartus 18.0 FPGA 5CSXFC6D6F31C6N 1. 实验项目 要求利用硬件描述语言Verilog(或VHDL)、图形描述方式、IP核,结合数字系统设计方法,在Quartus开发环境下&#xff…

Oracle日常管理(8)——OS日常管理(1)

8. Oracle日常管理 8.1. OS日常管理 8.1.1. OS系统日志 1)概念 服务器操作系统(OS)日常运行时,一般会生成系统日志并将其记录到相关文件中,这些日志会记录系统中一些重要配置、修改和报错等相关信息。运维人员、DBA或其他相关技术人员通过检查这些日志文件,可以对系统…

最大值的期望 与 期望的最大值

期望的最大值与最大值的期望 先上结论: m a x i E [ X i ] ≠ E [ m a x i X i ] max_i \mathbb{E}[X_i]\neq \mathbb{E}[max_i X_i] maxi​E[Xi​]E[maxi​Xi​] 情况一:最大值和数学期望都关于自变量 i i i 在这种情况下,最大值与期望都依赖于同一…