zoukankan      html  css  js  c++  java
  • 309. Best Time to Buy and Sell Stock with Cooldown

        /*
         * 309. Best Time to Buy and Sell Stock with Cooldown 
         * 2016-7-4 by Mingyang
         * http://buttercola.blogspot.com/2016/01/leetcode-best-time-to-buy-and-sell.html
         * 
         *1. Define States
         *
         *To represent the decision at index i:
         *buy[i]: Max profit till index i. The series of transaction is ending with a buy.
         *sell[i]: Max profit till index i. The series of transaction is ending with a sell.
         *To clarify:
         *Till index i, the buy / sell action must happen and must be the last action.
         * It may not happen at index i. It may happen at i - 1, i - 2, ... 0.
         *In the end n - 1, return sell[n - 1]. Apparently we cannot finally end up with a buy. 
         *In that case, we would rather take a rest at n - 1.
         *For special case no transaction at all, classify it as sell[i], so that in the end, we can still return sell[n - 1]. 
         *
         *2. Define Recursion
         *
         *buy[i]: To make a decision whether to buy at i, we either take a rest, by just using the old decision at i - 1, 
         *or sell at/before i - 2, then buy at i, We cannot sell at i - 1, then buy at i, because of cooldown.
         *sell[i]: To make a decision whether to sell at i, we either take a rest, by just using the old decision at i - 1, 
         *or buy at/before i - 1, then sell at i.
         *So we get the following formula:
         *buy[i] = Math.max(buy[i - 1], sell[i - 2] - prices[i]);   
         *sell[i] = Math.max(sell[i - 1], buy[i - 1] + prices[i]);
         */
         public int maxProfit5(int[] prices) {
                if (prices == null || prices.length <= 1) {
                    return 0;
                }
                int[] sell=new int[prices.length];
                int[] buy=new int[prices.length];
                buy[0] = -prices[0];
                sell[0] = 0;
                buy[1]=Math.max(buy[0],-prices[1]);
                sell[1]=Math.max(sell[0],buy[0]+prices[1]);
                for (int i = 2; i <prices.length; i++) {
                     buy[i]=Math.max(buy[i-1],sell[i-2]-prices[i]);
                     sell[i]=Math.max(sell[i-1],buy[i-1]+prices[i]);
                }
                return sell[prices.length-1];
            }
  • 相关阅读:
    Selenium WebDriver 中鼠标事件(全)
    日常知识积累加不定期更新(一)
    动作手游实时PVP技术揭密(服务器篇)
    Java RMI之HelloWorld篇
    java中注解的使用与实例 (二)
    RPC原理及RPC实例分析
    动作手游实时PVP帧同步方案(客户端)
    java中注解的使用与实例(一)
    动作手游实时PVP技术揭密(服务器篇)
    AS3.0 几何结构 Point对象和Rectangle对象
  • 原文地址:https://www.cnblogs.com/zmyvszk/p/5642162.html
Copyright © 2011-2022 走看看