代码随想录算法【Day40】

devtools/2025/2/12 7:15:30/

Day40

121. 买卖股票的最佳时机
class Solution {
public:int maxProfit(vector<int>& prices) {int len = prices.size();if (len == 0) return 0;vector<vector<int>> dp(len, vector<int>(2));dp[0][0] -= prices[0];dp[0][1] = 0;for(int i = 1; i < len; i++){dp[i][0] = max(dp[i - 1][0], -prices[i]);dp[i][1] = max(dp[i - 1][1], prices[i] + dp[i - 1][0]);}return dp[len - 1][1];}
};

五部曲

1.dp数组及下标定义:dp[i][0]:表示持有该股票得到的最大现金;dp[i][1]:表示不持有该股票得到的最大现金;

2.递推公式:

dp[i][0] = max(dp[i - 1][0], -prices[i]);

dp[i][1] = max(dp[i - 1][1], prices[i] + dp[i - 1][0]);

3.初始化:

dp[0][0] -= prices[0];所以dp[0][1] = 0

4.遍历顺序:从前到后遍历

5.数组的数据应该是怎样的:


http://www.ppmy.cn/devtools/158141.html

相关文章

Vue 3 中的 reactive 和 ref 有什么区别?

在 Vue 3 中,reactive 和 ref 是用于创建响应式状态的两个 API。虽然它们的目标都是使数据响应式,但它们的使用场景和实现方式有所不同。以下是它们之间的主要区别: 目录 何时使用 reactive 和 ref基本用法响应式对象的类型总结何时使用 reactive 和 ref reactive:适用于创…

Django在终端创建项目(pycharm Windows)

1.选择目录 选择或新建一个文件夹&#xff0c;作为项目保存的地方 2.右键在终端打开 3.确定django-admin.exe安装位置 找到自己安装django时&#xff0c;django-admin.exe安装的位置&#xff0c;例如 4.运行命令 使用django-admin.exe的绝对路径&#xff0c;在刚才打开的终端…

香港中文大学 Adobe 推出 MotionCanvas:开启用户掌控的电影级图像视频创意之旅。

简介&#xff1a; 亮点直击 将电影镜头设计引入图像到视频的合成过程中。 推出了MotionCanvas&#xff0c;这是一种简化的视频合成系统&#xff0c;用于电影镜头设计&#xff0c;提供整体运动控制&#xff0c;以场景感知的方式联合操控相机和对象的运动。 设计了专门的运动条…

Unity使用iTextSharp导出PDF-04图形

坐标系 pdf文档页面的原点&#xff08;0&#xff0c;0&#xff09;在左下角&#xff0c;向上为y,向右为x。 文档的PageSize可获取页面的宽高数值 单位&#xff1a;像素 绘制矢量图形 使用PdfContentByte类进行绘制&#xff0c;注意文档打开后才有此对象的实例。 绘制方法 …

Anything llm Token数理解

Token context window参数解释 1. 定义与范围 Token context window&#xff08;上下文窗口&#xff09;参数同时包含输入和输出的token总数限制&#xff0c;表示模型单次交互中能够处理的最大token容量。例如&#xff1a;- GPT-4&#xff1a;典型窗口为32k tokens&#xff0c;…

使用 C++20 Modules 导入 Boost 模块的方法

使用 C20 Modules 导入 Boost 模块的方法 我的项目案例地址&#xff1a;https://github.com/yudaichen/coroutine_blog 引言 C20 引入的 Modules 特性为 C 开发带来了诸多好处&#xff0c;如加快编译速度、减少头文件重复包含等问题。Boost 作为一个广泛使用的 C 库集合&…

(3/100)每日小游戏平台系列

新增一个颜色记忆挑战&#xff01; 游戏目标 在游戏中&#xff0c;你需要记住系统展示的颜色顺序&#xff0c;并按照相同的顺序点击颜色按钮。如果你点击正确&#xff0c;你将进入下一关&#xff0c;难度会逐步提升。记忆力越强&#xff0c;得分越高&#xff01; 游戏规则 开始…

C++ ——从C到C++

1、C的学习方法 &#xff08;1&#xff09;C知识点概念内容比较多&#xff0c;需要反复复习 &#xff08;2&#xff09;偏理论&#xff0c;有的内容不理解&#xff0c;可以先背下来&#xff0c;后续可能会理解更深 &#xff08;3&#xff09;学好编程要多练习&#xff0c;简…