买卖股票系列(力扣121、122、123、188、309、714) Java动态规划
创始人
2024-02-05 09:22:31
0

一、买卖股票的最佳时机(力扣121)

        121. 买卖股票的最佳时机-力扣

        使用两个变量,一个变量max来保存截止到当天获得的最大利润,另一个变量min来保存截止到当天股票的最小价格,动态规划即可求出所有的当天价格中,最大的价格

class Solution {public int maxProfit(int[] prices) {int min = prices[0];    //截止到当天,股票的最小价格int max = 0;            //截止到当天,买卖股票能获得的最佳利润for(int i=1; i

 

二、买卖股票的最佳时机 II(力扣122)

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

        2.1 贪心

        等价于每天都交易,只要是赚钱的就卖。(比如股票价格为2,3,4。2块钱买进,4块钱卖出 等价于 2块钱买3块钱卖,3块钱买4块钱卖) 

class Solution {public int maxProfit(int[] prices) {int res = 0;    //利润总和for(int i=1; i 0) {  //如果是赚钱的就卖res += temp;}}return res;}
}

        2.2 动态规划

        和下面的三一样的思路 :

class Solution {public int maxProfit(int[] prices) {int a = 0 - prices[0];  //持有股票的状态int b = 0;              //不持有股票的状态for(int i=0; i

 

三、最佳买卖股票时机含冷冻期(力扣309) 

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

        3.1 动态规划

         一天有三种状态:持有股票、处于冷冻期、无股票也不在冷冻期

        我们使用dp[i][]数组来表示第i天各种状态下的最大利润,

  • dp[i][0]        表示持有股票
  • dp[i][1]        表示不持有股票,在冷冻期(表示当天结束后处于冷冻期,即当天卖出了股票)
  • dp[i][2]        表示不持有股票,不在冷冻期

        那么,dp[i][0]的值取决于:因为当天持有股票,那么有两种情况:1、是之前一直持有的,此时i-1天必须持有股票,则值为dp[i-1][0];2、是当天刚买的,那么前一天不能持有股票,也不能再冷冻期,只可能是2状态,再扣去买股票的钱,则值为dp[i-1][2] - prices[i]。则:

                                dp[i][0] = max{ dp[i-1][0] , dp[i-1][2] - prices[i] }

        dp[i][1]的值取决于:因为dp[i][1]表示当天结束后处于冷冻期,即当天卖出了股票,则前一天必须持有股票,那么只要一种情况,即 dp[i-1] + prices[i]

        dp[i][2]的值取决于:因为当天既不持有股票,也不在冷冻期,说明前一天不持有股票,可能在冷冻期也可能不在,那么有两种情况:1、前一天在冷冻期,那么当天值为dp[i-1][1];2、前一天不在冷冻期,那么当天值为dp[i-1][2]。则:

                                dp[i][2] = max{ dp[i-1][1] , dp[i-1][2] }

        那么我们所求的是什么值呢?因为要想利润最大,最后一天必然不可能持有股票,所以我们要求的是    max{ dp[len-1][1] , dp[len-1][2] }

class Solution {public int maxProfit(int[] prices) {int len = prices.length;int [][]dp = new int[len][3];dp[0][0] = 0 - prices[0];dp[0][1] = 0;dp[0][2] = 0;for(int i=1; i

        3.2 优化空间

        其实当天的状态只与前一天有关,那么我们只用变量保存即可。 

class Solution {public int maxProfit(int[] prices) {int len = prices.length;int a = 0 - prices[0];int b = 0;int c = 0;for(int i=1; i

 

四、买卖股票的最佳时机含手续费 (力扣714)

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

        因为每次交易有手续费,就不能像2.1那样做了,但是2.2的做法是通用做法,只要在卖出股票的时候把手续费减掉就行。 

class Solution {public int maxProfit(int[] prices, int fee) {int a = 0 - prices[0];  //持有股票的状态int b = 0;              //不持有股票的状态for(int i=0; i

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...