代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、总结

本文主要是介绍代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码随想录算法训练营第五十三天

309.最佳买卖股票时机含冷冻期

题目链接:309.最佳买卖股票时机含冷冻期

class Solution {
public:int maxProfit(vector<int>& prices) {vector<vector<int>>dp(prices.size(),vector<int>(4,0));dp[0][0] = 0;//不操作dp[0][1] = -prices[0];//持有dp[0][2] = 0;//不持有dp[0][3] = 0;//冷冻期for(int i =1;i<prices.size();i++){dp[i][0] = 0;dp[i][1] = max(dp[i-1][1],dp[i-1][3]-prices[i]);dp[i][2] = max(dp[i-1][2],dp[i-1][1]+prices[i]);dp[i][3] = dp[i-1][2];}return dp[prices.size()-1][2];}
};

714.买卖股票的最佳时机含手续费

题目链接:714.买卖股票的最佳时机含手续费

class Solution {
public:int maxProfit(vector<int>& prices, int fee) {vector<vector<int>>dp(prices.size(),vector<int>(3,0));dp[0][0] = 0;//不操作dp[0][1] = -prices[0];//持有dp[0][2] = 0;//不持有for(int i =1;i<prices.size();i++){dp[i][0] = 0;dp[i][1] = max(dp[i-1][1],dp[i-1][2]-prices[i]);dp[i][2] = max(dp[i-1][2],dp[i-1][1]+prices[i]-fee);}return dp[prices.size()-1][2];}
};

总结

买卖股票的dp数组dp[i][j],i是第i天的价格,有j是状态,根据题目需要分为持有,不持有,第k次持有,第k次卖出后(买入前),冷却期等。需要了解当前状态可能是由前一天的哪种状态转变过来的。

  1. 买卖一次:
    不持有=保持前一天的不持有或当天卖出

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

    持有=保持前一天的持有或者当天买入

    dp[i][1] = max(dp[i-1][1],0-prices[i]);
    
  2. 买卖多次:
    不持有=保持前一天的不持有或当天卖出

    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]);
    
  3. 只能买卖2次:
    不操作:

    dp[i][0] = 0;
    

    第一次持有=保持之前持有或当天买入

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

    第一次不持有=保持之前不持有或当前卖出

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

    第二次持有=保持之前持有或者当天买入

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

    第二次不持有=保持之前持有或者当天卖出

    dp[i][4] = max(dp[i-1][4],dp[i-1][3]+prices[i]);
    
  4. 只能买卖k次:
    总共状态有2k种,第k次持有或第k次不持有

     if (j % 2 == 1) //奇数持有dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1] - prices[i]);else  //偶数不持有dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1] + prices[i]);
    
  5. 含冷冻期:
    不操作:

    dp[i][0] = 0;
    

    持有:

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

    不持有:

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

    冷冻期:

    dp[i][3] = dp[i-1][2];
    
  6. 含手续费:
    状态和2相同,卖出时多减一份手续费即可
    持有:

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

    不持有:

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

这篇关于代码随想录算法训练营第五十三天|309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1051527

相关文章

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Java Response返回值的最佳处理方案

《JavaResponse返回值的最佳处理方案》在开发Web应用程序时,我们经常需要通过HTTP请求从服务器获取响应数据,这些数据可以是JSON、XML、甚至是文件,本篇文章将详细解析Java中处理... 目录摘要概述核心问题:关键技术点:源码解析示例 1:使用HttpURLConnection获取Resp

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java