动态规划---股票交易问题总结

2024-02-08 06:38

本文主要是介绍动态规划---股票交易问题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.股票交易—需要冷却期

    /** 题目:需要冷却期的股票交易* 题目描述:交易之后需要有一天的冷却时间。* */public int maxProfit(int[] prices) {//方案一if(prices==null||prices.length==0||prices.length==1) return 0;int n=prices.length;int dp[]=new int[n];//dp[i]表示截至到第i个股票。手中最大的利润(此时已将股票卖出,手中无剩余股票)。dp[0]=0;dp[1]=prices[1]>prices[0]?prices[1]-prices[0]:0;for(int i=2;i<n;i++){dp[i]=dp[i-1];for(int j=0;j<i;j++){if(prices[i]>prices[j]){if(j<2) dp[i]=Math.max(dp[i],prices[i]-prices[j]);else dp[i]=Math.max(dp[i],dp[j-2]+prices[i]-prices[j]);}}}return dp[n-1];}public int maxProfit2(int[] prices) {//方案二if(prices==null||prices.length==0||prices.length==1) return 0;int n=prices.length;int dp1[]=new int[n];//dp1[i]表示截止到第i个股票,手中已经买入一张股票的 剩余最大资金。int dp2[]=new int[n];//dp2[i]表示截止到第i个股票,手中已经将股票卖出的 剩余最大资金。dp1[0]=-prices[0];dp2[0]=0;dp1[1]=Math.max(dp1[0],-prices[1]);dp2[1]=prices[1]-prices[0]>0?prices[1]-prices[0]:0;for(int i=2;i<prices.length;i++){/** i时刻处于买入状态的剩余最大资金 = 买的是之前的股票(dp1[i-1])和买当前股票(dp2[i-2]+prices[i])相比取最大值。* dp2[i-2]+prices[i]:因为在卖出股票后,必须有一天冷却期才能再买,所以取dp2[i-2](i-2时刻已经将所有股票都卖出后的资金状态),再减去买入当前股票的钱* */dp1[i]=Math.max(dp1[i-1],dp2[i-2]-prices[i]);/** i时刻处于卖出状态的剩余最大资金 = 卖的不是当前股票(dp2[i-1])和卖当前股票(dp1[i-1]+prices[i])相比取最大值。* dp1[i-1]+prices[i]:因为在买入股票后,下一刻就可以马上卖,所以取dp1[i-1](i-1时刻已经将买入一张股票后的资金状态),再加上卖掉当前股票的钱* */dp2[i]=Math.max(dp2[i-1],dp1[i-1]+prices[i]);}return dp2[n-1];}

2.需要交易费用的股票交易

    /** 需要交易费用的股票交易* 题目描述:每交易一次,都要支付一定的费用。* */public int maxProfit(int[] prices, int fee) {int n=prices.length;int sell[]=new int[n];//sell[i]表示遍历完第i个股票时,手中已经将股票卖出时的最大利润int hold[]=new int[n];//hold[i]表示遍历完第i个股票时,手中已经有一张股票时的最大利润sell[0]=0;hold[0]=-prices[0];for(int i=1;i<prices.length;i++){hold[i]=Math.max(hold[i-1],sell[i-1]-prices[i]);sell[i]=Math.max(sell[i-1],hold[i-1]+prices[i]-fee);}return sell[n-1];}

3.只能进行K次的股票交易

/** 只能进行 k 次的股票交易* */public int maxProfit(int k, int[] prices) {if(prices==null||prices.length==0||k==0) return 0;int n=prices.length;if(k>n/2){//此时退化为普通的多次股票交易问题int maxPro=0;for(int i=1;i<n;i++){if(prices[i]>prices[i-1]){maxPro+=prices[i]-prices[i-1];}}return maxPro;}int dp[][]=new int[k+1][n];//dp[i][j]表示前j天,最多进行i次交易的最大利益/*for(int i=1;i<=k;i++){//进行i次交易for(int j=1;j<n;j++){//前j天dp[i][j]=dp[i][j-1];//第j天不操作股票for(int p=0;p<j;p++){//第j天操作股票,在j天卖出. 遍历在之前的哪天买,能得到更大的利润if(prices[p]<prices[j])dp[i][j]=Math.max(dp[i][j],dp[i-1][p]+prices[j]-prices[p]);}}}*///把最大的dp[i-1][p]-prices[p]预先存储for(int i=1;i<=k;i++){//进行i次交易int maxPre=dp[i-1][0]-prices[0];for(int j=1;j<n;j++){//前j天dp[i][j]=Math.max(dp[i][j-1],maxPre+prices[j]);maxPre=Math.max(maxPre,dp[i-1][j]-prices[j]);}}return dp[k][n-1];}

这篇关于动态规划---股票交易问题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

C# List.Sort四种重载总结

《C#List.Sort四种重载总结》本文详细分析了C#中List.Sort()方法的四种重载形式及其实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录1. Sort方法的四种重载2. 具体使用- List.Sort();- IComparable

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文