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

在线体验各类最新模型,更有模型 免费Token 额度领取!
立即体验
简介: 带你读《图解算法小抄》二十一、动态规划(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

相关文章
|
SQL 缓存 Java
殷浩详解DDD系列 第三讲 - Repository模式
# 第三讲 - Repository模式 **写在前面** 这篇文章和上一篇隔了比较久,一方面是工作比较忙,另一方面是在讲Repository之前其实应该先讲Entity(实体)、Aggregate Root(聚合根)、Bounded Context(限界上下文)等概念。但在实际写的过程中,发现单纯讲Entity相关的东西会比较抽象,很难落地。所以本文被推倒重来,从Repository
39117 8
|
移动开发 算法 调度
【贪心算法】一文让你学会“贪心”(贪心算法详解及经典案例)
贪心算法是一种非常常见的算法,它的简单和高效性使其在实际应用中被广泛使用。 贪心算法的核心思想是在每一步都采取当前状态下最优的选择,而不考虑未来可能产生的影响。虽然贪心算法不能保证总是得到最优解,但在很多情况下,它可以获得很好的结果。 本篇文章将介绍贪心算法的基本概念和一些经典应用,以及如何通过贪心算法来解决一些实际问题。希望通过本文的阅读,读者可以对贪心算法有更加深刻的理解,并能够在实际问题中应用贪心算法来得到更好的解决方案。 让我们暴打贪心算法吧!
7013 0
|
Kubernetes Cloud Native Java
灰度发布、蓝绿部署、金丝雀都是啥?
在滚动部署中,应用的新版本逐步替换旧版本。实际的部署发生在一段时间内。在此期间,新旧版本会共存,而不会影响功能和用户体验。这个过程可以更轻易的回滚和旧组件不兼容的任何新组件。
灰度发布、蓝绿部署、金丝雀都是啥?
|
设计模式 存储 缓存
初探DDD
基于学习《殷浩详解DDD:领域层设计规范》后的动手实践,简单总结,以及个人理解
|
设计模式 弹性计算 人工智能
殷浩详解DDD:领域层设计规范
在一个DDD架构设计中,领域层的设计合理性会直接影响整个架构的代码结构以及应用层、基础设施层的设计。但是领域层设计又是有挑战的任务,特别是在一个业务逻辑相对复杂应用中,每一个业务规则是应该放在Entity、ValueObject 还是 DomainService是值得用心思考的,既要避免未来的扩展性差,又要确保不会过度设计导致复杂性。今天我用一个相对轻松易懂的领域做一个案例演示,但在实际业务应用中,无论是交易、营销还是互动,都可以用类似的逻辑来实现。
11156 11
殷浩详解DDD:领域层设计规范
|
XML Java 测试技术
详细讲解Spring中的@Bean注解
详细讲解Spring中的@Bean注解
1671 0
详细讲解Spring中的@Bean注解
|
消息中间件 存储 Dubbo
面试官:你是如何评估一个线程池需要设置多少个线程
面试官:你是如何评估一个线程池需要设置多少个线程
面试官:你是如何评估一个线程池需要设置多少个线程
|
9天前
|
人工智能 JSON 自然语言处理
让教学更智慧:用阿里云百炼工作流,自动生成中小学教材内容#小有可为#有温度的AI
通过可视化工作流编排,将大模型推理能力转化为标准化的教学内容生成引擎。教师只需输入教材标题和适用学段,即可自动获得结构完整、符合课程标准的章节内容,大幅降低备课门槛,助力教育资源均衡化。
483 125

热门文章

最新文章