代码随想录|121. 买卖股票的最佳时机,122.买卖股票的最佳时机II,123.买卖股票的最佳时机III,188.买卖股票的最佳时机IV

news2024/12/22 22:08:36

121. 买卖股票的最佳时机

dp含义

dp[i][0] 表示第i天持有股票所得最多现金 ,dp[i][1] 表示第i天不持有股票所得最多现金
其实一开始现金是0,那么加入第i天买入股票现金就是 -prices[i], 这是一个负数。

递推公式

第i天持有股票即dp[i][0],可以由两个状态推出来:

  • 第i-1天就持有股票,那么就保持限制,所得现金就是昨天持有股票的所得现金即dp[i-1][0],
  • 第i天买入股票,所得现金就是买入今天的股票后所得现金即:-prices[i]

所以dp[i][0]应该选所得现金最大的,所以dp[i][0]=max(dp[i-1][0],-prices[i]);

如果第i天不持有股票即dp[i][1].也可以由两个状态推出来

  • 第i-1天就不持有股票,那么就保持现状,所得现金就是昨天不持有股票的所得现金即dp[i-1][1]
  • 第i天卖出股票,所得现金就是买入今天的股票后所得现金即:prices[i]+dp[i-1][0]

同样dp[i][1]取最大的,dp[i][1]=max(dp[i-1][1],prices[i]+dp[i-1][0]);

dp数组如何初始化

由递推公式可以看出基础都是靠dp[0][0]和dp[0][1]推导出来的

那么dp[0][0]表示第0天持有股票,此时的持有股票就一定是买入股票,因为不可能有前一天推出来,所以dp[0][0]=-prices[0]

dp[0][1]表示第0天不持有股票,不持有股票就是dp[0][1]=0

确定遍历顺序

从前往后

推导dp数组

以示例1,输入:[7,1,5,3,6,4]为例,dp数组状态如下:

代码实现

class Solution {
    public int maxProfit(int[] prices) {
        int N=prices.length;
        int[][] dp=new int[N][2];
        dp[0][0]=-prices[0];//持有现金的最高现金
        dp[0][1]=0;//不持有股票拥有的最高现金
        for(int  i=1;i<N;i++){
            dp[i][0]=Math.max(dp[i-1][0],-prices[i]);
            dp[i][1]=Math.max(dp[i-1][1],prices[i]+dp[i-1][0]);
        }
        return dp[N-1][1];

    }
}

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

与上一题区别是可以多次买卖股票,所以和上一题唯一的区别就是本题股票可以买卖多次了(注意只有一只股票,所以再次购买前要出售掉之前的股票)。

如果第i天持有股票即dp[i][0], 那么可以由两个状态推出来

第i-1天就持有股票,那么就保持现状,所得现金就是昨天持有股票的所得现金 即:dp[i - 1][0]
第i天买入股票,所得现金就是昨天不持有股票的所得现金减去 今天的股票价格 即:dp[i - 1][1] - prices[i]
 

class Solution {
    public int maxProfit(int[] prices) {

        int N=prices.length;
        int[][] dp=new int[N][2];
        dp[0][0]=-prices[0];//持有现金的最高现金
        dp[0][1]=0;//不持有股票拥有的最高现金
        for(int  i=1;i<N;i++){
            dp[i][0] =Math. max(dp[i - 1][0], dp[i - 1][1] - prices[i]); 
            // 注意这里是和121. 买卖股票的最佳时机唯一不同的地方。
            dp[i][1]=Math.max(dp[i-1][1],prices[i]+dp[i-1][0]);
        }
        return dp[N-1][1];
       


    }
}

123.买卖股票的最佳时机III

dp含义

就是同一天可能存在四种状态
确定dp数组以及下标的含义
一天一共就有五个状态,

0没有操作 (其实我们也可以不设置这个状态)
1第一次持有股票
2第一次不持有股票
3第二次持有股票
4第二次不持有股票
dp[i][j]中 i表示第i天,j为 [0 - 4] 五个状态,dp[i][j]表示第i天状态j所剩最大现金。

需要注意:dp[i][1],表示的是第i天,买入股票的状态,并不是说一定要第i天买入股票,这是很多同学容易陷入的误区。
dp数组初始化
dp[0][0]=0
dp[0][1]=-prices[0]
 dp[0][2]=0//相当于当天买入当天卖出,没有赚钱,持有现金是0
dp[0][3]=-prices[0] //第二次买入,相当于在第0天,发生买入然后卖出然后又买入
dp[0][4]=0//相当于当天发生了买入,卖出,再买入,再卖出
递推公式
dp[i][1]=Math.max(dp[i-1][1],dp[i-1][0]-price[i])
dp[i][2] = max(dp[i - 1][1] + prices[i], dp[i - 1][2])
dp[i][3]=Math.max(dp[i-1][3],dp[i-1][2]-prices[i])
确定遍历顺序
从递归公式其实已经可以看出,一定是从前向后遍历,因为dp[i],依靠dp[i - 1]的数值。

举例推导dp数组
以输入[1,2,3,4,5]为例

代码实现

class Solution {
    public int maxProfit(int[] prices) {
        // if(prices.length)
        //不操作,第一次买入,第一次卖出,第二次买入,第二次卖出
        int N=prices.length;
        int[][] dp=new int[N][5];
        dp[0][1]=-prices[0];//dp[0][2]=0,dp[0][4]=0
        dp[0][3]=-prices[0];
        for(int i=1;i<prices.length;i++){
            dp[i][0]=dp[i-1][0];
            dp[i][1]=Math.max(dp[i-1][1],dp[i-1][0]-prices[i]);//第一次买入
            
            dp[i][2]=Math.max(dp[i-1][2],dp[i-1][1]+prices[i]);//第一次卖出
            dp[i][3]=Math.max(dp[i-1][3],dp[i-1][2]-prices[i]);
            dp[i][4]=Math.max(dp[i-1][4],dp[i-1][3]+prices[i]);


        }
        return dp[prices.length-1][4];

    }
}

188.买卖股票的最佳时机IV

dp含义
相比于123题就是可以买入卖出k次,所以思路基本是一样的,只是要加一些循环
使用二维数组 dp[i][j] :第i天的状态为j,所剩下的最大现金是dp[i][j]

j的状态表示为:

0 表示不操作

1 第一次买入

2 第一次卖出

3 第二次买入

4 第二次卖出

.....

除了0以外,偶数就是卖出,奇数就是买入

在初始化的地方同样要类比j为偶数是卖、奇数是买的状态。

确定遍历顺序
从递归公式其实已经可以看出,一定是从前向后遍历,因为dp[i],依靠dp[i - 1]的数值。

举例推导dp数组
以输入[1,2,3,4,5],k=2为例。

代码实现

这道题和上一题唯一的区别就是在初始化和递推公式的区别

class Solution {
    public int maxProfit(int k, int[] prices) {
        // if(prices.length)
        //不操作,第一次买入,第一次卖出,第二次买入,第二次卖出
        int N=prices.length;
        int[][] dp=new int[N][2*k+1];
        //初始化
        for(int i=1;i<2*k;i+=2){
            dp[0][i]=-prices[0];
        }
        // dp[0][1]=-prices[0];//dp[0][2]=0,dp[0][4]=0
        // dp[0][3]=-prices[0];
        for(int i=1;i<prices.length;i++){
            for(int j=1;j<2*k;j+=2){
            dp[i][j]=Math.max(dp[i-1][j],dp[i-1][j-1]-prices[i]);//第一次买入
            
            dp[i][j+1]=Math.max(dp[i-1][j+1],dp[i-1][j]+prices[i]);//第一次卖出


            }
            // dp[i][0]=dp[i-1][0];
            // dp[i][3]=Math.max(dp[i-1][3],dp[i-1][2]-prices[i]);
            // dp[i][4]=Math.max(dp[i-1][4],dp[i-1][3]+prices[i]);
        }
        return dp[prices.length-1][2*k];

    }
}

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

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

相关文章

Oracle数据库体系结构(三)_逻辑结构

Oracle逻辑存储结构,主要描述oracle 数据库内部数据的组织和管理方式&#xff0c;即在数据库管理系统的层面中如何组织和管理数据&#xff0c;与操作系统没有关系。逻辑存储结构时候物理存储机构的抽象体现&#xff0c;是不可见的&#xff0c;可以通过查询数据库数据字典了解逻…

RocketMq(一)安装部署

一、linux单机部署&#xff1a; 1、到apache官网下载 | RocketMQ (apache.org)下载binary zip包&#xff0c;如我下载的4.9.6版本。 上传到建好的/usr/local/rocketmq目录下。 2、解压zip包 unzip rocketmq-all-4.9.6-bin-release.zip 3、进入解压后的文件夹,启动 Name Serv…

TCP详解之流量控制

TCP详解之流量控制 发送方不能无脑的发数据给接收方&#xff0c;要考虑接收方处理能力。 如果一直无脑的发数据给对方&#xff0c;但对方处理不过来&#xff0c;那么就会导致触发重发机制&#xff0c;从而导致网络流量的无端的浪费。 为了解决这种现象发生&#xff0c;TCP 提…

关于QGC Landing Pattern规划的计算过程

固定翼飞机在规划航线时&#xff0c;QGC提供了自动生成降落阶段航线功能。在地图上选择降落点之后&#xff0c;根据默认的下滑坡度或下滑距离、盘旋点半径&#xff0c;自动生成航线。最后的降落航向实际由三个点组成&#xff0c;开始降落点&#xff08;MAV_CMD_DO_LAND_START&a…

SSM整合01

SSM01搭建SSM项目 1.创建maven的web工程 1.1pom.xml配置 <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http://maven.apac…

【每日一题】981. 基于时间的键值存储

981. 基于时间的键值存储 - 力扣&#xff08;LeetCode&#xff09; 设计一个基于时间的键值数据结构&#xff0c;该结构可以在不同时间戳存储对应同一个键的多个值&#xff0c;并针对特定时间戳检索键对应的值。 实现 TimeMap 类&#xff1a; TimeMap() 初始化数据结构对象void…

开始为 Android 开发 PWA 或混合 Web 应用

&#x1f3ac; 岸边的风&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! 目录 PWA 或混合 Web 应用的功能 Apache Cordova Ionic 通过安装所需工具开始使用 Ionic 使用 Ionic Cordova 和 Ang…

小白新手一文完成Git+Github/GITEE傻瓜式入门详解部署教程(内含TortoiseGit配置)

本文创作时版本为 Git-2.41.0&#xff0c;使用目标为笔记存储和代码库&#xff0c;部分公司向使用的设置可能不一样 一 Git 1.1 何为 Git Git是一款免费、开源的分布式版本控制系统&#xff0c;用于敏捷高效地处理项目、项目版本管理。 原本是为了帮助管理 Linux 内核开发而开…

Docker 网络学习

docker的网络模式 当你开始大规模使用Docker时&#xff0c;你会发现需要了解很多关于网络的知识。Docker作为目前最火的轻量级容器技术&#xff0c;有很多令人称道的功能&#xff0c;如Docker的镜像管理。然而&#xff0c;Docker同样有着很多不完善的地方&#xff0c;网络方面…

ARM64汇编基础

ARM64汇编基础 主要内容 到目前为止&#xff0c;大部分的移动设备都是64位的arm架构&#xff0c;一直想抽个时间系统学习下&#xff0c;这个周末就专门来学习下。毕竟两天的时间&#xff0c;也只是简单的入门了解下&#xff0c;为后续工作和学习打下基础。 本次学习的主要内容…

Pytorch学习笔记(GPU训练)

GUP训练 配置pytorch的gup版本主要是在网络模型、输入和标记的数据、损失函数 方式一 直接.cuda()调用&#xff0c;在原有的模型训练代码中的网络模型、输入和标记的数据、损失函数部分直接调用即可 方式二 事先定义好设备device,然后直接.to(device)调用&#xff0c;在原…

基于SSM的学生宿舍管理系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

[vulntarget靶场] vulntarget-a

靶场地址&#xff1a;https://github.com/crow821/vulntarget 拓扑结构 信息收集 主机发现 netdiscover -r 192.168.127.0/24 -i eth0端口扫描 nmap -A -sC -v -sV -T5 -p- --scripthttp-enum 192.168.127.130访问目标80&#xff0c;发现为通达oa WIN7漏洞利用 通达oa后台…

运行软件报错msvcr100.dll丢失的解决方法,全面分析msvcr100.dll丢失问题

随着科技的飞速发展&#xff0c;计算机已经成为人们生活和工作中不可或缺的重要工具。然而&#xff0c;在使用计算机的过程中&#xff0c;难免会遇到一些令人困扰的问题&#xff0c;如计算机丢失 msvcr100.dll 文件就是其中之一。本文将详细介绍计算机丢失 msvcr100.dll 的困扰…

文件打开表有几个?——参考《王道考研》

一、 真题试练 解析&#xff1a; 二、关于文件打开表 三、 疑问&#xff1f; 不是说好的只维护一个文件打开表吗&#xff1f; 四、解答 OS维护的是总的文件打开表&#xff0c;各自用户由对应各自的打开表&#xff0c;所有用户的打开表组成OS总的打开表。

layui框架学习(45: 工具集模块)

layui的工具集模块util支持固定条、倒计时等组件&#xff0c;同时提供辅助函数处理时间数据、字符转义、批量事件处理等操作。   util模块中的fixbar函数支持设置固定条&#xff08;2.7版本的帮助文档中叫固定块&#xff09;&#xff0c;是指固定在页面一侧的工具条元素&…

swift 事件

多个元素链接到单个IBAction 并区分

图书信息管理系统

#include<stdio.h> #include<string.h> #include<stdlib.h> #define MAXSIZE 10000typedef struct {char no[100];//图书ISBNchar name[100];//图书名字double price;//图书价格 } Book;typedef struct {Book data[MAXSIZE];int length; } SqList,*PSqList;P…

算法基础:图

图论 图论〔Graph Theory〕是数学的一个分支。它以图为研究对象。图论中的图是由若干给定的点及连接两点的线所构成的图形&#xff0c;这种图形通常用来描述某些事物之间的某种特定关系&#xff0c;用点代表事物&#xff0c;用连接两点的线表示相应两个事物间具有这种关系。 …

Java实现Ip地址获取

Java实现Ip地址获取 一、两种实现方式二、测试结果 一、两种实现方式 package com.lyp;import org.apache.commons.lang3.ObjectUtils;import java.net.*; import java.util.ArrayList; import java.util.Enumeration; import java.util.List; import java.util.Optional;/***…