带你读《图解算法小抄》二十一、动态规划(9)

简介: 带你读《图解算法小抄》二十一、动态规划(9)

带你读《图解算法小抄》二十一、动态规划(8)https://developer.aliyun.com/article/1347955?groupCode=tech_library


15.买卖股票的最佳时机 II

1)题目描述

给定一个数组 prices,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。

 

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

2)解题步骤

为了计算买卖股票的最佳时机 II,我们可以使用动态规划的思想来解决问题。

 

  • 定义状态:我们可以将问题转化为对于每个交易日的状态,即持有股票和未持有股票。令 dp[i][0] 表示第 i 天未持有股票时的最大利润,dp[i][1] 表示第 i 天持有股票时的最大利润。
  • 初始状态:对于第一天,我们有以下初始状态:dp[0][0] = 0,因为第一天不持有股票,利润为0。
  • dp[0][1] = -prices[0],因为第一天持有股票,利润为买入价格的相反数。状态转移方程:对于第 i 天,我们可以进行以下操作:
  • 如果第 i 天未持有股票,那么最大利润为前一天未持有股票的最大利润 dp[i-1][0],或者前一天持有股票并在第 i 天卖出所得到的利润 dp[i-1][1] + prices[i] 中的较大值。
  • 如果第 i 天持有股票,那么最大利润为前一天持有股票的最大利润 dp[i-1][1],或者前一天未持有股票并在第 i 天买入所得到的利润 dp[i-1][0] - prices[i] 中的较大值。

 

  • 综上所述,我们可以得到状态转移方程为:
  • dp[i][0] = max(dp[i-1][0], dp[i-1][1] + prices[i])
  • dp[i][1] = max(dp[i-1][1], dp[i-1][0] - prices[i])

 

  • 最终解:问题的解即为最后一天未持有股票时的最大利润,即 dp[n-1][0],其中 n 是交易日的总数。

下面是使用动态规划解决买卖股票的最佳时机 II 问题的算法框架:

 

function maxProfit(prices) {
  const n = prices.length;  if (n < 2) {
    return 0;
  }  const dp = new Array(n).fill(0).map(() => new Array(2).fill(0));  dp[0][0] = 0;
  dp[0][1] = -prices[0];  for (let i = 1; i < n; i++) {
    dp[i][0] = Math.max(dp[i - 1][0], dp[i - 1][1] + prices[i]);
    dp[i][1] = Math.max(dp[i - 1][1], dp[i - 1][0] - prices[i]);
  }  return dp[n - 1][0];
}


带你读《图解算法小抄》二十一、动态规划(10)https://developer.aliyun.com/article/1347953?groupCode=tech_library

相关文章
|
缓存 druid Java
SpringBoot源码 | prepareContext方法解析
本文主要讲述SpringBoot启动流程源码中的prepareContext()方法
SpringBoot源码 | prepareContext方法解析
|
存储 缓存 运维
ES运维常见的十个故障诊断指令汇总
ES运维常见的十个故障诊断指令汇总
ES运维常见的十个故障诊断指令汇总
|
4月前
|
运维 监控 安全
在多人协作的项目中,如何避免代码被误回滚?
在多人协作的项目中,如何避免代码被误回滚?
247 57
|
SQL 缓存 Java
殷浩详解DDD系列 第三讲 - Repository模式
# 第三讲 - Repository模式 **写在前面** 这篇文章和上一篇隔了比较久,一方面是工作比较忙,另一方面是在讲Repository之前其实应该先讲Entity(实体)、Aggregate Root(聚合根)、Bounded Context(限界上下文)等概念。但在实际写的过程中,发现单纯讲Entity相关的东西会比较抽象,很难落地。所以本文被推倒重来,从Repository
37804 8
|
移动开发 算法 调度
【贪心算法】一文让你学会“贪心”(贪心算法详解及经典案例)
贪心算法是一种非常常见的算法,它的简单和高效性使其在实际应用中被广泛使用。 贪心算法的核心思想是在每一步都采取当前状态下最优的选择,而不考虑未来可能产生的影响。虽然贪心算法不能保证总是得到最优解,但在很多情况下,它可以获得很好的结果。 本篇文章将介绍贪心算法的基本概念和一些经典应用,以及如何通过贪心算法来解决一些实际问题。希望通过本文的阅读,读者可以对贪心算法有更加深刻的理解,并能够在实际问题中应用贪心算法来得到更好的解决方案。 让我们暴打贪心算法吧!
6298 0
|
存储 JSON Kubernetes
基于 cri-dockerd 二进制部署 kubernetest-v1.26.3 2
基于 cri-dockerd 二进制部署 kubernetest-v1.26.3
201 0
|
设计模式 存储 缓存
初探DDD
基于学习《殷浩详解DDD:领域层设计规范》后的动手实践,简单总结,以及个人理解
|
Kubernetes Cloud Native Java
灰度发布、蓝绿部署、金丝雀都是啥?
在滚动部署中,应用的新版本逐步替换旧版本。实际的部署发生在一段时间内。在此期间,新旧版本会共存,而不会影响功能和用户体验。这个过程可以更轻易的回滚和旧组件不兼容的任何新组件。
灰度发布、蓝绿部署、金丝雀都是啥?
|
XML Java 数据库连接
解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题
解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题
14133 2
解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题
|
数据采集 前端开发 关系型数据库
修剪字符串:深入了解MySQL中的TRIM()函数
在数据库操作中,去除字符串首尾的空格或特定字符是常见的需求,这时可以使用MySQL中的TRIM()函数。本文将深入探讨TRIM()函数的用法、示例以及在数据库操作中的应用。
1474 0