zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 714 买卖股票的最佳时机含手续费(动态规划 || 迭代法)

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

    给定一个整数数组 prices,其中第 i 个元素代表了第 i 天的股票价格 ;非负整数 fee 代表了交易股票的手续费用。

    你可以无限次地完成交易,但是你每次交易都需要付手续费。如果你已经购买了一个股票,在卖出它之前你就不能再继续购买股票了。

    返回获得利润的最大值。

    示例 1:

    输入: prices = [1, 3, 2, 8, 4, 9], fee = 2
    输出: 8
    解释: 能够达到的最大利润:  
    在此处买入 prices[0] = 1
    在此处卖出 prices[3] = 8
    在此处买入 prices[4] = 4
    在此处卖出 prices[5] = 9
    总利润: ((8 - 1) - 2) + ((9 - 4) - 2) = 8.
    

    注意:

    0 < prices.length <= 50000.
    0 < prices[i] < 50000.
    0 <= fee < 50000.

    class Solution {
        //  public int maxProfit(int[] prices, int fee) {
        //     int size = prices.length;
    
        //     if (size <= 1){
        //         return 0;
        //     }
    
        //     int[][] dp = new int[size+1][2];
        //     dp[0][0] = 0; dp[0][1]= Integer.MIN_VALUE;
        //dp【】【0】就是手里没有股票反之dp[][1]就是手里有股票
        //     for(int day = 0; day < size; day++){
        //         dp[day+1][0] = dp[day][0];
        //         if (day > 0 && dp[day][1] != Integer.MIN_VALUE){
        //             dp[day+1][0] = Math.max(dp[day+1][0], dp[day][1] + prices[day] - prices[day-1] - fee);
        //         }
    
        //         dp[day+1][1] = dp[day][0];
        //         if (day > 0 && dp[day][1] != Integer.MIN_VALUE){
        //             dp[day+1][1] = Math.max(dp[day+1][1], dp[day][1] + prices[day] - prices[day-1]);
        //         }
        //     }
    
        //     return dp[size][0];
        // }
         public int maxProfit(int[] prices, int fee) {
            int length = prices.length;
            int keepMax = -prices[0];
            int notKeepMax = 0;
    
            for (int i = 1; i < length; i++) {
                int keepMaxYesterday = keepMax;
                keepMax = Math.max(keepMax, notKeepMax - prices[i]);
                notKeepMax = Math.max(notKeepMax, keepMaxYesterday + prices[i] - fee);
            }
            return notKeepMax;
        }
    }
    
  • 相关阅读:
    几个计算广告学的课程
    Jie Bao 牛人cv
    如果英剧《黑镜子》拍第三季,你来写一集剧本策划,你想写一个什么样的故事呢? 知乎
    设计模式之迭代器与组合模式
    javascript 时钟clock
    项目中的需求蔓延
    一个产生随机random markers 例子
    设计模式之模板方法模式
    设计模式之反(向)模式
    转:用函数式编程技术编写优美的 JavaScript
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13074765.html
Copyright © 2011-2022 走看看