力扣121. 买卖股票的最佳时机

Problem: 121. 买卖股票的最佳时机

文章目录

题目描述

思路

1.定义一个int数组max大小同prices;定义int变量curMax初始化为0;

2.从后往前遍历数组,若当前元素prices[i] > curMax 时,则使将其赋值给curMax再将curMax填写到max[i];

3.定义int变量result再从前往后遍历,若price[i] - max[i] > result,则更新result,最后返回result。

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n为数组prices的大小;

空间复杂度:

O ( n ) O(n) O(n)

Code

cpp 复制代码
class Solution {
public:
    /**
     * Suffix sum
     * @param prices
     * @return int
     */
    int maxProfit(vector<int> &prices) {
        int n = prices.size();
        vector<int> max(n);
        int curMax = 0;
        //Statistical suffix sum
        for (int i = n - 1; i >= 0; --i) {
            max[i] = curMax;
            if (prices[i] > curMax) {
                curMax = prices[i];
            }
        }
        int result = 0;
        for (int i = 0; i < n; ++i) {
            if (max[i] - prices[i] > result) {
                result = max[i] - prices[i];
            }
        }
        return result;
    }
};
相关推荐
地平线开发者9 分钟前
大模型 | VLM 初识及在自动驾驶场景中的应用
算法·自动驾驶
lingran__23 分钟前
算法沉淀第四天(Winner)
c++·算法
AIzealot无26 分钟前
Qwen3 Embedding报告随笔
人工智能·深度学习·算法·论文·embedding·论文笔记·搜广推
zzzsde27 分钟前
【C++】深入理解string类(5)
java·前端·算法
清风wxy1 小时前
C语言基础数组作业(冒泡算法)
c语言·开发语言·数据结构·c++·windows·算法
IT小番茄1 小时前
Kubernetes云平台管理实战:如何创建Deployment更好(九)
算法
白云千载尽1 小时前
leetcode 2598 执行操作后最大MEX
算法·leetcode·职场和发展
岁月向前1 小时前
网络数据大端序和小端序
算法
懒羊羊不懒@2 小时前
算法入门数学基础
c语言·数据结构·学习·算法
mit6.8242 小时前
[Sora] 从检查点恢复训练 | `Booster`接口 | EMA模型 | .safetensors
人工智能·算法·机器学习