剑指offer 71. 股票的最大利润

简介: 剑指offer 71. 股票的最大利润

题目描述


假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖 一次 该股票可能获得的利润是多少?


例如一只股票在某些时间节点的价格为 [9,11,8,5,7,12,16,14]。


如果我们能在价格为 5 的时候买入并在价格为 16 时卖出,则能收获最大的利润 11。


数据范围

输入数组长度 [0,500]。

样例

输入:[9, 11, 8, 5, 7, 12, 16, 14]
输出:11


方法一:一次遍历 O(n)


这道题我们可以用一个变量 minv 来记录数组中最小值,然后在遍历的过程中不断更新。因为题意是需要输出最大利润,所以我们需要使买入股票的价格尽可能的小,并且卖出股票的价格尽可能大,拿题目的样例进行举例,假设有数组 [9, 11, 8, 5, 7, 12, 16, 14]


第一步: 初始化 minv 为第一个数 9 ,且 ans = 0


1aed44eb297c408892928ca8a4f795a3.png

第二步: 计算差值 11 - 9 > ans = 0 ,故更新 ans = 2 ,且 11 > 9 ,所以 minv 不用更新。


80c6b62ce2264c848884405501ad5ad3.png


第三步: 计算差值 8 - 9 < ans = 2 ,故不用更新 ans ,且 8 < 9 ,所以更新 minv = 8 。

3e376754f0a54f2da4280410dc80d1ae.png



第四步: 计算差值 5 - 8 < ans = 2 ,故不用更新 ans ,且 5 < 8 ,所以更新 minv = 5 。

69f499a9802e40e5a8fa788a1a7e000e.png


第五步: 计算差值 7 - 5 = ans = 2 ,故不用更新 ans ,且 7 > 5 ,所以 minv 不用更新。

2421edc259ee420cb7386df593afe76c.png



第六步: 计算差值 12 - 5 > ans = 2 ,故更新 ans = 7 ,且 12 > 5 ,所以 minv 不用更新。


0690eb3c1f42435f8b38afc93d0560c1.png


第七步: 计算差值 16 - 5 > ans = 7 ,故更新 ans = 11 ,且 16 > 5 ,所以 minv 不用更新。

89b947cf27524eb8b8aae1683fbacfdd.png


第八步: 计算差值 14 - 5 < ans = 11 ,故不用更新 ans ,且 14 > 5 ,所以 minv 不用更新。此时已经遍历到最后一个值,故直接返回结果 ans = 11

class Solution {
public:
    int maxDiff(vector<int>& nums) {
        if (nums.empty())    return 0;
        int minv = nums[0], ans = 0;
        for (int i = 1; i < nums.size(); i++)
        {
            ans = max(ans, nums[i] - minv);
            minv = min(minv, nums[i]);
        }
        return ans;
    }
};



欢迎大家在评论区交流~

目录
相关文章
|
6月前
|
算法
《LeetCode》—— 买卖股票的最佳时机
《LeetCode》—— 买卖股票的最佳时机
|
算法
【动态规划刷题 7】 买卖股票的最佳时机含冷冻期&& 买卖股票的最佳时机含手续费
【动态规划刷题 7】 买卖股票的最佳时机含冷冻期&& 买卖股票的最佳时机含手续费
|
22天前
|
存储
(剑指Offer)10、菲波那切数列I—10、青蛙跳台阶问题II—63、股票的最大利润(2021/12/04)
(剑指Offer)10、菲波那切数列I—10、青蛙跳台阶问题II—63、股票的最大利润(2021/12/04)
28 0
|
5月前
动态规划——买卖股票的最佳时机含冷冻期
动态规划——买卖股票的最佳时机含冷冻期
29 1
|
5月前
|
算法
leetcode题解:121.买卖股票的最佳时机
leetcode题解:121.买卖股票的最佳时机
40 0
|
6月前
|
算法
【力扣】121. 买卖股票的最佳时机、122.买卖股票的最佳时机Ⅱ
【力扣】121. 买卖股票的最佳时机、122.买卖股票的最佳时机Ⅱ
|
6月前
|
算法
leetcode121. 买卖股票的最佳时机
leetcode121. 买卖股票的最佳时机
35 0
|
6月前
代码随想录 Day43 动态规划11 LeetCode T309 买卖股票的最佳时期含冷冻期 T714买卖股票的最佳时机含手续费
代码随想录 Day43 动态规划11 LeetCode T309 买卖股票的最佳时期含冷冻期 T714买卖股票的最佳时机含手续费
51 0
|
6月前
|
算法
leetcode-121:买卖股票的最佳时机
leetcode-121:买卖股票的最佳时机
44 0
|
12月前
|
算法
代码随想录算法训练营第五十天 | LeetCode 309. 买卖股票的最佳时机含冷冻期、714. 买卖股票的最佳时机含手续费、股票系列总结
代码随想录算法训练营第五十天 | LeetCode 309. 买卖股票的最佳时机含冷冻期、714. 买卖股票的最佳时机含手续费、股票系列总结
75 1