leetcode122-买卖股票的最佳时机II

leetcode 122

思路

方法一的核心思想是简单的贪心策略。我们每天都看当前价格和下一个价格的差值。如果下一个价格高于当前价格(即diff > 0),那么就认为当天可以买入并在第二天卖出,赚取利润。因此,方法一把所有的价格差(即diff > 0的部分)累加起来,最终得出最大利润

步骤:

遍历整个数组,计算相邻两个价格的差值

如果差值为正(表示价格上涨),则加入利润

powershell 复制代码
时间复杂度:O(n),其中 n 是 prices 数组的长度,因为只需要遍历一遍数组
空间复杂度:O(1),只使用了常量空间

方法二模拟买入和卖出的策略 重点是通过标记是否已经持有股票来区分买入和卖出时机

通过比较当前和前一个价格差(curdiff 和 prediff)来决定买入和卖出。

flag 标志用来表示当前是否持有股票。如果持有股票且价格下跌,则卖出;如果没有股票且价格上涨,则买入。

在循环结束后,检查是否还有未卖出的股票,如果有则在最后时刻卖出

方法二和之前的摆动序列很相似,也可以参考此博文

实现

方法1-贪心算法
js 复制代码
var maxProfit = function (prices) {
    let sum = 0;
    for (let i = 0; i < prices.length - 1; i++) {
        let diff = prices[i + 1] - prices[i]
        if (diff > 0) {
            // 可以买入
            sum += diff
        }
    }
    return sum;
};
方法2
js 复制代码
var maxProfit = function (prices) {
  let prediff = 0, curdiff = 0;
  let sum = 0, flag = false;
  for (let i = 0; i < prices.length - 1; i++) {
    curdiff = prices[i + 1] - prices[i];
    if (curdiff > 0 && prediff <= 0) {
      // 可以买入
      sum -= prices[i]
      flag = true
      prediff = curdiff
    }
    if (flag && curdiff < 0 && prediff >= 0) {
      // 可以卖出
      sum += prices[i]
      flag = false;
      prediff = curdiff
    }
  }
  // 到最后都还没有卖出,把最后一个卖掉
  if (flag) {
    sum += prices[prices.length - 1]
  }
  return sum;
};
相关推荐
牧羊狼的狼1 分钟前
React 中的 HOC 和 Hooks
前端·javascript·react.js·hooks·高阶组件·hoc
知识分享小能手1 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
mCell2 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
~|Bernard|3 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师3 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo33 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
weixin_437830944 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
好家伙VCC4 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
gnip5 小时前
JavaScript事件流
前端·javascript