我最近解决了一个经典的 LeetCode 问题:“买卖股票的最佳时机”。这道题要求你求出一次买卖股票所能获得的最大利润。让我们深入探讨我探索过的不同方法及其复杂性。这是问题的 URL:
LeetCode 121
蛮力方法(时间复杂度:O(n^2))
最直接的解决方案可能是将数组中的每个元素与所有剩余元素进行比较。对于每个价格,我们计算如果在稍后的一天出售它会产生的利润。然后我们跟踪遇到的最大利润。然而,这种方法的时间复杂度较高,导致 Time Limit Exceeded。
/** * @param {number[]} prices * @return {number} */ var maxProfit = function (prices) { let max = 0; for (var i = 0; i a) return b - a; else return 0; }
原因如下: 我们将每个元素与 n-1 个其他元素进行比较,从而产生 n*(n-1)/2 次比较。这大致相当于 O(n^2) 时间复杂度,对于大型数据集来说效率很低。不幸的是,这种方法经常会导致 LeetCode 出现“Time Limit Exceeded”错误。
二指针方法(时间复杂度:O(n))
为了提高效率,我们可以利用先买后卖的事实。我们可以引入两个指针:
- 购买:指向当前的潜在购买价格。
- sell:指向候选售价。
这个想法是从第三个元素开始迭代价格数组(因为前两个元素用于买卖)。我们不断检查卖出价(当前元素)和买入价之间的差额是否大于当前最大利润。如果为真,我们更新最大利润。否则,我们将买入指针更新为当前元素(可能是较低的买入价格)并将卖出指针向前移动一步。
这种方法显着提高了时间复杂度,达到了 O(n),因为我们只迭代数组一次。
/** * @param {number[]} prices * @return {number} */ var maxProfit = function (prices) { let maxProfit = 0; let buy = 0; let sell = 1; while (sell <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/172284027594031.png?x-oss-process=image/resize,p_40" class="lazy" alt="LeetCode 问题:买卖股票的最佳时机" loading="lazy" style="max-width:90%" style="max-width:90%"></p> <h2> 贪婪方法(时间复杂度:O(n))与 Python 示例 </h2> <p>我们可以通过贪心方法实现类似的时间复杂度。这里的关键是要明白,只有低买高卖才能实现最大利润。 因此,我们可以迭代价格数组并跟踪迄今为止遇到的最低价格。这代表了潜在的购买价格。</p> <p>这是贪婪方法的 Python 实现:<br> </p> <pre class="brush:php;toolbar:false">class Solution: def maxProfit(self, prices: List[int]) -> int: max_profit = 0; min_buy = float('inf') for price in prices: min_buy = min(min_buy , price ) max_profit = max(max_profit, price-min_buy) return max_profit
您可以随时了解更多有关在我的作品集上还可以在哪里找到我的信息
以上是LeetCode 问题:买卖股票的最佳时机的详细内容。更多信息请关注PHP中文网其他相关文章!

Linux终端中查看Python版本时遇到权限问题的解决方法当你在Linux终端中尝试查看Python的版本时,输入python...

本文解释了如何使用美丽的汤库来解析html。 它详细介绍了常见方法,例如find(),find_all(),select()和get_text(),以用于数据提取,处理不同的HTML结构和错误以及替代方案(SEL)

Python的statistics模块提供强大的数据统计分析功能,帮助我们快速理解数据整体特征,例如生物统计学和商业分析等领域。无需逐个查看数据点,只需查看均值或方差等统计量,即可发现原始数据中可能被忽略的趋势和特征,并更轻松、有效地比较大型数据集。 本教程将介绍如何计算平均值和衡量数据集的离散程度。除非另有说明,本模块中的所有函数都支持使用mean()函数计算平均值,而非简单的求和平均。 也可使用浮点数。 import random import statistics from fracti

本文比较了Tensorflow和Pytorch的深度学习。 它详细介绍了所涉及的步骤:数据准备,模型构建,培训,评估和部署。 框架之间的关键差异,特别是关于计算刻度的

在使用Python的pandas库时,如何在两个结构不同的DataFrame之间进行整列复制是一个常见的问题。假设我们有两个Dat...

本文指导Python开发人员构建命令行界面(CLIS)。 它使用Typer,Click和ArgParse等库详细介绍,强调输入/输出处理,并促进用户友好的设计模式,以提高CLI可用性。

本文讨论了诸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和请求等流行的Python库,并详细介绍了它们在科学计算,数据分析,可视化,机器学习,网络开发和H中的用途

文章讨论了虚拟环境在Python中的作用,重点是管理项目依赖性并避免冲突。它详细介绍了他们在改善项目管理和减少依赖问题方面的创建,激活和利益。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver CS6
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。