zoukankan      html  css  js  c++  java
  • 122. 买卖股票的最佳时机 II

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

    设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。

    注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

    示例 1:

    输入: [7,1,5,3,6,4]
    输出: 7
    解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
      随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6-3 = 3 。

    const int maxn=1e5+5;
    int dp[maxn][2];
    class Solution {
    public:
        int maxProfit(vector<int>& prices) {
            // 1 代表 持有 , 0 代表 没有
            int siz=prices.size();
            //memset(dp,0,sizeof(dp));
            dp[0][1]=-prices[0];
            dp[0][0]=0;
            int ans=0;
            for(int i=1;i<siz;++i){
                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]);
                ans=max(ans,max(dp[i][0],dp[i][1]));
                cout<<dp[i][0]<<' '<<dp[i][1]<<endl;
            }
            return ans;
        }
    };
    

      

  • 相关阅读:
    UVA 10618 Tango Tango Insurrection
    UVA 10118 Free Candies
    HDU 1024 Max Sum Plus Plus
    POJ 1984 Navigation Nightmare
    CODEVS 3546 矩阵链乘法
    UVA 1625 Color Length
    UVA 1347 Tour
    UVA 437 The Tower of Babylon
    UVA 1622 Robot
    UVA127-"Accordian" Patience(模拟)
  • 原文地址:https://www.cnblogs.com/DreamKill/p/13225279.html
Copyright © 2011-2022 走看看