【LeetCode】188. 买卖股票的最佳时机 IV(困难)——代码随想录算法训练营Day50

本文主要是介绍【LeetCode】188. 买卖股票的最佳时机 IV(困难)——代码随想录算法训练营Day50,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:188. 买卖股票的最佳时机 IV

题目描述

给你一个整数数组 prices 和一个整数 k ,其中 prices[i] 是某支给定的股票在第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你最多可以完成 k 笔交易。也就是说,你最多可以买 k 次,卖 k 次。

注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

示例 1:

输入:k = 2, prices = [2,4,1]
输出:2
解释:在第 1 天 (股票价格 = 2) 的时候买入,在第 2 天 (股票价格 = 4) 的时候卖出,这笔交易所能获得利润 = 4-2 = 2 。

示例 2:

输入:k = 2, prices = [3,2,6,5,0,3]
输出:7
解释:在第 2 天 (股票价格 = 2) 的时候买入,在第 3 天 (股票价格 = 6) 的时候卖出, 这笔交易所能获得利润 = 6-2 = 4 。随后,在第 5 天 (股票价格 = 0) 的时候买入,在第 6 天 (股票价格 = 3) 的时候卖出, 这笔交易所能获得利润 = 3-0 = 3 。

提示:

  • 1 <= k <= 100
  • 1 <= prices.length <= 1000
  • 0 <= prices[i] <= 1000

文章讲解:

视频讲解:

题解1:动态规划

思路:本题是 123. 买卖股票的最佳时机 III 的增强版,可以将 dp 数组定义成三维数组。

动态规划分析:

  • dp 数组以及下标的含义:

    dp 是一个三维数组,每行 k + 1个元素。dp[i][k][0] 表示第 i 天第 k 次持有股票所得的最大现金,dp[i][k][1] 代表第 i 天第 k 次不持有股票所得的最大现金。

  • 递推公式:dp[i][j][0] = Math.max(dp[i - 1][j][0], dp[i - 1][j - 1][1] - prices[i]),dp[i][j][1] = Math.max(dp[i - 1][j][1], dp[i - 1][j][0] + prices[i]);
  • dp 数组初始化:dp[0][k][0] = -prices[0]。
  • 遍历顺序:从前到后。
  • 打印 dp 数组:以输入k = 2、prices = [2,4,1] 为例,dp 数组为 [ [ [ 0, 0 ], [ -2, 0 ], [ -2, 0 ] ], [ [ 0, 0 ], [ -2, 2 ], [ -2, 2 ] ], [ [ 0, 0 ], [ -1, 2 ], [ 1, 2 ] ] ]。
/*** @param {number} k* @param {number[]} prices* @return {number}*/
var maxProfit = function(k, prices) {const dp = new Array(prices.length).fill().map(() => new Array(k + 1).fill().map(() => new Array(2).fill(0)));for (let j = 1; j <= k; j++) {dp[0][j][0] = -prices[0];}for (let i = 1; i < prices.length; i++) {for (let j = 1; j <= k; j++) {dp[i][j][0] = Math.max(dp[i - 1][j][0], dp[i - 1][j - 1][1] - prices[i]);dp[i][j][1] = Math.max(dp[i - 1][j][1], dp[i - 1][j][0] + prices[i]);}}return dp[prices.length - 1][k][1];
};

分析:时间复杂度为 O(n),空间复杂度为 O(n * k)。

题解2:动态规划优化

思路:dp[i] 的状态只依赖于 dp[i - 1] 的状态,可以用一个变量 cur 保存 dp[i - 1],动态更新此变量。

/*** @param {number} k* @param {number[]} prices* @return {number}*/
var maxProfit = function(k, prices) {const cur = new Array(k + 1).fill().map(() => new Array(2).fill(0));for (let j = 1; j <= k; j++) {cur[j][0] = -prices[0];}for (let i = 1; i < prices.length; i++) {for (let j = 1; j <= k; j++) {cur[j][0] = Math.max(cur[j][0], cur[j - 1][1] - prices[i]);cur[j][1] = Math.max(cur[j][1], cur[j][0] + prices[i]);}}return cur[k][1];
};

分析:时间复杂度为 O(n * k),空间复杂度为 O(k)。

收获

练习使用动态规划求解买卖股票问题,体验状态压缩降低空间复杂度的过程。

这篇关于【LeetCode】188. 买卖股票的最佳时机 IV(困难)——代码随想录算法训练营Day50的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/774183

相关文章

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.