● 121. 买卖股票的最佳时机 ● 122.买卖股票的最佳时机II

news2025/1/12 20:08:11

● 121. 买卖股票的最佳时机

因为只能买卖一次,所以左边找一个最小的,右边找一个最大的,相减的差就是最大的利润。那么用贪心来做:

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        //vector<int> dp(n,vector<int>(n,0));
        int minprice=INT_MAX;
        int result=INT_MIN;
        for(int i=0;i<n;++i){
            minprice=min(minprice,prices[i]);
            result=max(result,prices[i]-minprice);
        }
        return result;
    }
};

回归到动规,动规五部曲:
1.dp数组元素含义。dp[j][0]:第j天持有股票的最大现金(买了还没卖出,是负数)。dp[j][1]:第j天未持有股票的最大现金(非负数,没买或已卖出)。最后返回的是dp[n-1][1],因为最后手上没股票。

2.递推公式。dp[j][0]=max(dp[j-1][0],-prices[j])。dp[j][1]=max(dp[j-1][1],dp[j][0]+prices[j])。

3.初始化。刚开始现金是0,下标为0的时候对应第一天,第一天只能持有股票,所以dp[0][0]=-prices[i],dp[0][1]=0(不会覆盖后面dp[j][1]取max).

4.遍历顺序。从左到右

5.打印。

代码:

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        vector<vector<int>> dp(n,vector<int>(2));
        dp[0][0]=-prices[0];
        dp[0][1]=0;
        for(int j=1;j<n;++j){
            dp[j][0]=max(dp[j-1][0],-prices[j]);
            dp[j][1]=max(dp[j-1][1],dp[j][0]+prices[j]);
        }
        return dp[n-1][1];
    }
};

又∵在循环体中始终只涉及j和j-1的dp数组,所以可以只设置dp数组个数为2的滚动数组,节省空间。

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        vector<vector<int>> dp(2,vector<int>(2));
        dp[0][0]=-prices[0];
        dp[0][1]=0;
        for(int j=1;j<n;++j){
            dp[j%2][0]=max(dp[(j-1)%2][0],-prices[j]);
            dp[j%2][1]=max(dp[(j-1)%2][1],dp[j%2][0]+prices[j]);
        }
        return dp[(n-1)%2][1];
    }
};

正如之前说,贪心类的简单的很简单,这道题用贪心很快且好想,用动规五部曲还繁琐一些。但是为下道题目打了基础。


● 122.买卖股票的最佳时机II

这道题是贪心部分做过的一道题,还记得其贪心思路:“第i天买入,第j天卖出”,和“第i天买入,中间每天都既卖出又买入,第j天卖出”一样的效果。可以顺便复习一下之前用贪心的写法。

动规:

1.dp数组含义。

和上面一样:dp[j][0]:第j天持有股票的最大现金。dp[j][1]:第j天未持有股票的最大现金。

2.递推公式。注意和贪心算法的不同,当下标到j,意味着前j-1天的已经处理,不能再动了。

先看dp[j][0],两种情况:如果前一天j-1持有股票,第j天不能卖仍然得持有,就还等于dp[j-1][0];如果前一天j-1没有股票,第j天买入,就为dp[j-1][1]-prices[j]。所以dp[j][0]=max( dp[j-1][0], dp[j-1][1]-prices[j])。

再看dp[j][1],也是两种情况:第j-1天有股票,第j天要卖掉,为dp[j-1][0]+prices[j];没有股票,第j天不买入,为dp[j-1][1]。所以dp[j][1]=max( dp[j-1][0]+prices[j], dp[j-1][1])。

3.初始化。同上。

4.遍历顺序。同上。

5.打印。

代码如下。可见和上题唯一不同的是递推公式。

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        vector<vector<int>> dp(2,vector<int>(2));
        dp[0][0]=-prices[0];
        dp[0][1]=0;
        for(int j=1;j<n;j++){
            dp[j%2][0]=max( dp[(j-1)%2][0], dp[(j-1)%2][1]-prices[j]);
            dp[j%2][1]=max( dp[(j-1)%2][0]+prices[j], dp[(j-1)%2][1]);
        }            
        return dp[(n-1)%2][1];     
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1497440.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在 echarts 的 rich 中使用 iconfont 图标库图标作为 backgroundColor.image 值的方法

实现步骤 1、引入 iconfont.js。该脚本执行时&#xff0c;会在 body 下插入一个 svg 标签&#xff0c;标签下包含了图标库中的 svg 图标 path。 <script src"your/iconfont/path/iconfont.js"></script>或者 import your/iconfont/path/iconfont.js2、…

如何禁止员工在上班时间利用电脑打游戏逛娱乐网站?

在现代化的工作环境中&#xff0c;电脑已成为员工日常工作的必需品。然而&#xff0c;一些员工可能在上班时间利用电脑进行非工作相关的活动&#xff0c;如打游戏或浏览娱乐网站。这不仅影响个人的工作效率&#xff0c;也可能对团队的整体绩效和公司的文化产生负面影响。因此&a…

饮料换购 刷题笔记

直接开个计数器mask 每当饮料现存数-1&#xff1b; cnt;且mask; 一旦mask达到3 饮料现存数 计数器清零3 代码 #include <iostream> #include<cstdio> #include<algorithm> #include<cstring> using namespace std; int main(){ int n; …

火爆全网,软件测试数据库常用 SQL 语句总结,你要的我都有......

前言 直接上干货 数据定义语言(DDL) 主要负责数据库、数据表、视图、键、索引等结构化的操作 常用的语句有&#xff1a;CREATE DATABASE、CREATE TABLE、ALTER TABLE等 字段的常用约束有&#xff1a;PRIMARY KEY、FOREIGN KEY、NOT NULL、UNIQUE、AUTO_INCREMENT、DEFAULT 常…

使用nginx输入端口号显示404

输入对应的端口号显示404 先检查当前nginx文件夹的路径是没有中文的查看是否没有开启nginx&#xff1a;ctrlaltdelete打开任务管理器&#xff0c;看看有没有nginx.exe进程&#xff08;一般是有两个进程&#xff09;如果没有进程说明没有打开nginx&#xff0c;查看端口号是否被…

菜鸟笔记-14散点图标记形状

大家在学习Python科研绘图中&#xff0c;总会涉及散点图标记形状&#xff0c;为了方便大家学习应用&#xff0c;博主通过学习搜集&#xff0c;将这部分技巧总结如下。 14.1默认散点图 14.1.1图像呈现 14.1.2绘图代码 import numpy as np # 导入numpy库&#xff0c;用于处理…

创建RAID0,RAID5并管理,热备盘,模拟故障

目录 1. RAID介绍以及mdadm安装 1.1 安装mdadm工具 2. 创建raid0 2.1 环境准备 2.2 使用两个磁盘创建RAID0 2.3 查看RAID0信息 2.4 对创建的RAID0进行格式化并挂载 2.5 设置成开机挂载 2.6 删除RAID0 3. 创建raid5 3.1 环境准备 3.2 用3个磁盘来模拟R…

Spring boot2.7整合jetcache 远程redis缓存方案

前文 java Spring boot简述jetcache 并叙述后续文章安排 我们讲述了 jetcache 的基本概念 那么 本文 我们现在开始 直接开工 首先 要保证 redis启动 而且 要将其中全部的键值对清空掉 pom.xml中 加入坐标 <!-- https://mvnrepository.com/artifact/com.alicp.jetcache/je…

C++初阶 类(上)

目录 1. 什么是类 2. 如何定义出一个类 3. 类的访问限定符 4. 类的作用域 5. 类的实例化 6. 类的大小 7. this指针 1.this指针的引出 2. this指针的特性 8. 面试题 1. 什么是类 在C语言中&#xff0c;不同类型的数据集合体是结构体。为了方便管理结构体&#xff0c;我…

HCIP---IS-IS协议

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 一.IS-IS协议概述 IS-IS是一种基于链路状态的内部网关协议&#xff08;IGP&#xff09;&#xff0c;它使用最短路径优先算法&#xff08;SPF或Dijkstra&#xff09;进行路由计算。这种协议在自治…

MySQl基础入门⑤

上一遍知识内容 1.数据表的结构及数据完整性的设计 1、关系型数据库 关系型数据库是一个结构化的数据库&#xff0c;创建在关系模型&#xff08;二维表格模型&#xff09;基础上&#xff0c;一般面向于记录。SQL 语句&#xff08;标准数据查询语言&#xff09;就是一种基于关…

精准获客、优化体验,Xinstall数据自动分析全搞定

在移动互联网时代&#xff0c;App已经成为了我们生活中不可或缺的一部分。然而&#xff0c;对于App开发者来说&#xff0c;如何有效地评估渠道效果、精准获客以及优化用户体验&#xff0c;一直是一个令人头疼的问题。幸运的是&#xff0c;Xinstall作为一款一站式App全渠道统计服…

组合逻辑电路(一)(加法器)

目录 组合逻辑电路的特点及功能描述 采用SSI的组合逻辑电路的分析与设计 采用SSI的组合逻辑电路的分析 采用SII的组合逻辑电路的设计 例 例 例 常用的MSI组合逻辑电路 半加器 全加器 加法器 串行进位加法器 例 例 超前进位加法器 组合逻辑电路的特点及功能描述 小规模集成…

洗地机怎么选?家用洗地机推荐!海尔/希亦/美的/小米洗地机哪个牌子更值得买

近年来&#xff0c;智能清洁产品也是一大热门品类&#xff0c;尤其是对于城市上班族来说&#xff0c;购买一款智能清洁产品&#xff0c;既能够让家里保持干净&#xff0c;而且清洁起来也省时省力&#xff0c;可谓是一举两得。而洗地机凭借易用性、实用性以及便利性等优势&#…

STM32 | Proteus 8.6安装步骤(图文并茂)

01 Proteus 8.6 简介 Proteus 8.6 是一款功能强大的电子设计自动化软件,广泛用于电路设计、仿真和PCB布局。它为电子工程师和学生提供了一个全面的工具集,用于设计和验证各种电路和电子设备。Proteus 8.6 包括了以下几个主要特性: 1. 电路设计和仿真:Proteus 8.6 提供了一…

SSM框架,SSM框架的整合

SSM整合的介绍 微观&#xff1a;将Spring SpringMVC Mybatis框架应用到项目中 SpringMVC框架负责控制层Spring 框架负责整体和业务层的声明式事务管理MyBatis框架负责数据库访问层 宏观&#xff1a;Spring接管一切&#xff08;将框架核心组件交给Spring进行IoC管理&#xff09…

C++_程序流程结构_跳转语句_break

break 作用 用于跳出选择结构或循环结构 break使用的时机 出现在switch条件语句中&#xff0c;作用是终止case并跳出switch出现在循环语句中&#xff0c;作用是跳出当前的循环语句出现在嵌套循环中&#xff0c;跳出最近的内层循环语句 示例1 示例2 示例3

Java单元测试实战

简介 在开发中&#xff0c;发现很多人并不理解什么是单元测试&#xff0c;容易和集成测试混淆&#xff0c;所以专门写一章来讲解&#xff0c;再拓展一下如果获得代码测试覆盖率。我们通常可以将测试分为两大类&#xff0c;一种是集成测试&#xff0c;一种是单元测试。 集成测…

5G与智慧文旅的融合发展:推动旅游业转型升级与可持续发展

随着5G技术的飞速发展和广泛应用&#xff0c;其与智慧文旅的融合发展正成为推动旅游业转型升级与可持续发展的重要力量。5G技术以其高速率、低时延、大连接的特性&#xff0c;为智慧文旅注入了新的活力&#xff0c;助力旅游业实现更高效、更智能、更绿色的发展。本文将深入探讨…

Bert Encoder和Transformer Encoder有什么不同

前言&#xff1a;本篇文章主要从代码实现角度研究 Bert Encoder和Transformer Encoder 有什么不同&#xff1f;应该可以帮助你&#xff1a; 深入了解Bert Encoder 的结构实现深入了解Transformer Encoder的结构实现 本篇文章不涉及对注意力机制实现的代码研究。 注&#xff1a;…