leetcode_188 Best Time to Buy and Sell Stock IV

题目分析:

  • 用一个数组表示股票每天的价格,数组中第i个数表示股票在第i天的价格。最多可以交易k次,但手上只能持有一支股票,求此时的最大收益。

解题思路:

  • 动态规划求解

    1)如果交易次数大于股票变化的天数,次数利用贪心法求解最大收益即可。

    2)如果不满足1),则从所有的价格变化序列中,挑选出2*k个元素,组成交易,交易过程为交替进行。此时利用动态规划进行求解。利用两个数组分别记录:当前到达第i天最多可以进行j次交易所得到的最大利润global[i][j]和当前到达第i天最多可以进行j次交易,而且最后一次交易在当天卖出所得到的最大利润。对应的转移方程为:

    global[i][j] = max(local[i][j], global[i-1][j])

    local[i][j] = max(global[i-1][j-1] + max(diff,0), local[i-1][j] + diff)。

  • 实现程序

    class Solution
    {
        public:
            int maxProfit(int k, vector<int> &prices)
            {
                // 如果交易次数大于股票价格变化的天数,此时贪心法,求最大收益即可。 
                if (k >= prices.size())
                {
                    return maxProfit2(prices);
                }
                // 记录到达第i天最多可以进行j次交易,所得到的最大利润 
                vector<int> max_local(k + 1, 0);
                // 记录到达第i天最可以进行j次交易,而且最后一次交易在当天卖出,所得到的最大利润 
                vector<int> max_global(k + 1, 0);
                int diff;
                for (int i = 0; i < prices.size() - 1; i++)
                {
                    // 第i天进行交易的利润 
                    diff = prices[i + 1] - prices[i];
                    for (int j = k; j >= 1; j--)
                    {
                        max_local[j] = max(max_global[j - 1] + max(diff, 0), max_local[j] + diff);
                        max_global[j] = max(max_local[j], max_global[j]);
                    }
                } 
                return max_global[k];
            }
            int maxProfit2(vector<int> &prices)
            {
                if (prices.size() < 2)
                    return 0;
                int profit = 0;
                for (int i = 0; i < prices.size() - 1; i++)   //注意(int)prices.size() - 1与prices.size() - 1结果值不同 
                {
                    if (prices[i + 1] > prices[i])
                        profit += prices[i + 1] - prices[i];
                }
                return profit;
            } 
    };
    

参考文献:http://blog.csdn.net/foreverling/article/details/43911309

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值