代码随想录算法训练营第四十二天-动态规划-股票-188.买卖股票的最佳时机IV

embedded/2025/2/6 15:48:43/
  • 题目要求进行k次买卖
  • 其实就是上一题的扩展,把2次扩展为k次
  • 定义动规数组依然是二维,第一个维度表示第几天,第二个维度表示第几次买入和卖出
  • 所以第二个维度的长度应该是2k+1
  • 在for循环内,要使用一个内循环来表示第几次买入或卖出,根据上一题的过程,可以发现其中的规律
class Solution {
public:int maxProfit(int k, std::vector<int>& prices) {int len = prices.size();if (len == 0) {return 0;}std::vector<std::vector<int>> dp(len, std::vector<int>(2 * k + 2, 0));for (int i = 0; i < 2 * k; i += 2) {dp[0][i + 1] = -prices[0];}for (int i = 1; i < len; ++i) {for (int j = 0; j < 2 * k; j += 2) {dp[i][j + 1] = std::max(dp[i - 1][j + 1], dp[i - 1][j] - prices[i]);dp[i][j + 2] = std::max(dp[i - 1][j + 2], dp[i - 1][j + 1] + prices[i]);}}return dp[len - 1][2 * k];}
};
  • 汇总

http://www.ppmy.cn/embedded/160068.html

相关文章

如何使用深度学习中的 Transformer 算法进行视频目标检测

以下将介绍如何使用深度学习中的 Transformer 算法进行视频目标检测&#xff0c;并给出一个复现相关论文思路及示例代码。这里以 DETR&#xff08;End-to-End Object Detection with Transformers&#xff09;为基础进行说明&#xff0c;它是将 Transformer 引入目标检测领域的…

Ubuntu22.04如何设置linux-lowlatency核心

在Ubuntu上设置 linux-lowlatency 内核可以帮助减少系统延迟&#xff0c;适合需要低延迟环境的任务&#xff08;如音频处理、实时应用等&#xff09;。以下是设置步骤&#xff1a; 1. 更新系统 首先&#xff0c;确保系统是最新的&#xff1a; sudo apt update sudo apt upgr…

ElasticSearch 学习课程入门(二)

引子 前文已经介绍了ES的增删改查基本操作&#xff0c;接下来&#xff0c;我们学习下高级点的用法。OK&#xff0c;那就让我们开始吧。 一、ES高级操作 1、条件查询 &#xff08;1&#xff09;GET https://127.0.0.1:9200/shopping/_search?qcategory:小米 &#xff08;2&…

【Leetcode 每日一题 - 补卡】922. 按奇偶排序数组 II

问题背景 给定一个非负整数数组 n u m s nums nums&#xff0c; n u m s nums nums 中一半整数是 奇数 &#xff0c;一半整数是 偶数 。 对数组进行排序&#xff0c;以便当 n u m s [ i ] nums[i] nums[i] 为奇数时&#xff0c; i i i 也是 奇数 &#xff1b;当 n u m s [ …

【分布式架构理论3】分布式调用(1):负载均衡

文章目录 零、三种不同的负载均衡一、常见行业负载均衡方案1. 电商与互联网服务2. 金融与支付系统3. 云计算与分布式存储 二、负载均衡策略概述1. 无状态负载均衡&#xff08;强调公平性&#xff09;2. 有状态的负载均衡&#xff08;强调正确性&#xff09; 三、 总结 零、三种…

Linux 系统上安装 Docker 方法详解与比较

Docker 是现代 DevOps 和容器化应用开发的重要工具&#xff0c;它简化了应用的部署和管理流程。本文将详细介绍在 Linux 系统上安装 Docker 的多种方法&#xff0c;并对它们的适用场景、优缺点进行对比&#xff0c;确保读者能够根据自身需求选择最优方案。 1. 官方推荐的安装方…

【算法】动态规划专题④ ——LCS(最长公共子序列)+ LPS(最长回文子序列) python

目录 前置知识LCS举一反三LPS 前置知识 【算法】动态规划专题③ ——二维DP python 子序列定义为&#xff1a; 不改变剩余字符顺序的情况下&#xff0c;删除某些字符或者不删除任何字符形成的一个序列。 LCS 最长公共子序列 https://www.lanqiao.cn/problems/1189/learning/?p…

传输层协议 UDP 与 TCP

&#x1f308; 个人主页&#xff1a;Zfox_ &#x1f525; 系列专栏&#xff1a;Linux 目录 一&#xff1a;&#x1f525; 前置复盘&#x1f98b; 传输层&#x1f98b; 再谈端口号&#x1f98b; 端口号范围划分&#x1f98b; 认识知名端口号 (Well-Know Port Number) 二&#xf…