【Leetcode 热题 100】121. 买卖股票的最佳时机

问题背景

给定一个数组 p r i c e s prices prices,它的第 i i i 个元素 p r i c e s [ i ] prices[i] prices[i] 表示一支给定股票第 i i i 天的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 0 0。

数据约束

  • 1 ≤ p r i c e s . l e n g t h ≤ 1 0 5 1 \le prices.length \le 10 ^ 5 1≤prices.length≤105
  • 0 ≤ p r i c e s [ i ] ≤ 1 0 4 0 \le prices[i] \le 10 ^ 4 0≤prices[i]≤104

解题过程

整体是贪心算法,思想是维护好前缀最小值,然后不断更新最大差值即可。

具体实现

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int min = Integer.MAX_VALUE;
        int res = 0;
        for(int price : prices) {
            res = Math.max(res, price - min);
            min = Math.min(min, price);
        }
        return res;
    }
}
相关推荐
记忆多8 分钟前
c++名字空间 函数模版 左右值
开发语言·c++·算法
三伏52213 分钟前
控制理论前置知识——相平面数学基础2(示例部分)
算法·平面·控制
2401_889884661 小时前
高性能计算通信库
开发语言·c++·算法
郝YH是人间理想1 小时前
Pandas库DataFrame数据结构
数据结构·pandas
不想看见4041 小时前
Hamming Distance位运算基础问题--力扣101算法题解笔记
算法
像污秽一样2 小时前
算法与设计与分析-习题4.1
算法·链表·排序算法
lhc200906252 小时前
【作业】 贪心算法
算法·贪心算法
天若有情6732 小时前
循环条件隐藏陷阱:我发现了「同循环双条件竞态问题」
c++·学习·算法·编程范式·while循环··竞态
j_xxx404_2 小时前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久2 小时前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构