JS 刷 Leetcode:121买卖股票的最佳时机

简介: JS 刷 Leetcode:121买卖股票的最佳时机

1. 题目

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

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

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

示例 1:

输入:[7,1,5,3,6,4]
输出:5
解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
     注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。

示例 2:

输入:prices = [7,6,4,3,1]
输出:0
解释:在这种情况下, 没有交易完成, 所以最大利润为 0。

提示:

  • 1 <= prices.length <= 105
  • 0 <= prices[i] <= 104

2. 解一:暴力法

这种方法简单明了,就是套两个循环,将每种情况下的收入算出取最大值。

/**
 * @param {number[]} prices
 * @return {number}
 */
var maxProfit = function(prices) {
  let result = 0
  const len = prices.length
  for(let i = 0; i < len - 1; i++) {
    for(let j = i + 1; j < len; j++) {
      const earnings = prices[j] - prices[i]
      if(earnings > result) {
        result = earnings
      }
    }
  }
  return result
};

复杂度分析:

  • 时间复杂度:O(n2)
  • 空间复杂度:O(1)

image.png
可以看到直接超时了

3. 解二:动态规划(Dynamic programming)

我们假设我们来买股票,那么什么时候会有更高的收益呢? 那肯定是股价最低的时候买入,股价最高的时候卖出。
而且这里有个前提就是股价最高的点要在最低之后。

我们可以定义两个指针变量InDay=0outDay=1分别表示买入的时间点和卖出的时间点
最大收益maxNum=0
我们就可以开始遍历数组在遇到股价比之前记录的低的点的时候,重新开始计算最大利润。

/**
 * @param {number[]} prices
 * @return {number}
 */
 var maxProfit = function(prices) {
  let inDay = maxNum = 0
  let outDay = 1
  const len = prices.length
  for(let i = 1;i < len; i++,outDay++) {
    const earnings = prices[outDay] - prices[inDay]
    maxNum = Math.max(earnings, maxNum)

    if(prices[i] < prices[inDay] ) {
      inDay = outDay = i
    }
    
  }
  return maxNum
};

复杂度分析:

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

image.png

相关文章
|
5月前
|
算法 Python
【Leetcode刷题Python】309. 最佳买卖股票时机含冷冻期
解决LeetCode上309题“最佳买卖股票时机含冷冻期”的Python代码示例,利用动态规划方法计算在含有冷冻期约束下的最大利润。
46 1
|
5月前
|
算法 Python
【Leetcode刷题Python】121. 买卖股票的最佳时机
解决LeetCode上121题“买卖股票的最佳时机”的Python代码示例,采用一次遍历的方式寻找最佳买卖时机以获得最大利润。
67 1
|
5月前
|
算法
leetcode188 买卖股票的最佳时机IV
leetcode188 买卖股票的最佳时机IV
73 0
|
5月前
|
JavaScript 数据安全/隐私保护 Python
东方财富股票数据JS逆向:secids字段和AES加密实战
东方财富股票数据JS逆向:secids字段和AES加密实战
107 0
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的废品买卖回收管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的废品买卖回收管理系统附带文章源码部署视频讲解等
53 3
|
5月前
|
算法 Python
【Leetcode刷题Python】714. 买卖股票的最佳时机含手续费
提供了两种解决买卖股票最佳时机含手续费问题的Python实现方法:贪心算法和动态规划算法。
53 0
|
5月前
|
算法 Python
【Leetcode刷题Python】122.买卖股票的最佳时机 II
LeetCode "买卖股票的最佳时机 II" 问题的Python代码实现,采用贪心算法在股票价格上升的每一天买入并卖出,以获得最大利润。
29 0
|
7月前
|
算法
leetcode题解:121.买卖股票的最佳时机
leetcode题解:121.买卖股票的最佳时机
50 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
133 2