day51|● 309.最佳买卖股票时机含冷冻期 ● 714.买卖股票的最佳时机含手续费

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

此题目中有四个不同的状态,需要针对这四种状态来分析:

0:状态一 持有股票状态

1:状态二 保持卖出股票的状态(两天前就卖出了股票,度过一天冷冻期。

         或者是前一天就是卖出股票状态,一直没操作)

2:状态三 今天卖出股票

3:状态四 今天为冷冻期状态,但冷冻期状态不可持续,只有一天!

class Solution {
public:

    int maxProfit(vector& prices) {
        int n =prices.size();
        if(n==0) return 0;
        vector> dp(n,vector(4,0));
        dp[0][0] -=prices[0];
        for(int i=1;i < n;i++){
            dp[i][0] = max(dp[i - 1][0], 
                max(dp[i - 1][3] - prices[i], dp[i - 1][1] - prices[i]));
            dp[i][1] = max(dp[i - 1][1], dp[i - 1][3]);
            dp[i][2] = dp[i - 1][0] + prices[i];
            dp[i][3] = dp[i - 1][2];
        }
        return max(dp[n-1][3],max(dp[n-1][1],dp[n-1][2]));
    }
};

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

在每次卖出的时候把手续费也算上,一同进行比较。

class Solution {
public:
    int maxProfit(vector& prices, int fee) {
        int n = prices.size();
        vector> dp(n,vector(2,0));
        dp[0][0] -=prices[0];
        for(int i=1;i

你可能感兴趣的:(算法,leetcode,动态规划)