LeetCode 笔记23 Best Time to Buy and Sell Stock III
Best Time to Buy and Sell Stock III
Say you have an array for which the ith element is the price of a given stock on day i.
Design an algorithm to find the maximum profit. You may complete at most two transactions.
现在A股涨这么好,要是股票都提前知道价格就好了(@_@)
首先,考虑如果至多只能做一次交易呢?
那很简单嘛,大家都知道O(n^2)的方法,两个循环,确定(buyDay, sellDay)取到最大的profit。
怎么优化呢?
其实如果只做一次交易,那么遍历一次数组就可以了。
从0开始,到最后一天。在遍历到第i天的时候,我们用prices[i]减去当前所知道的最小的price,看一下是否比当前max profit大,如果是,就更新max profit。
我们不用关心后面的更小值哦,因为它们不影响当前profit,毕竟你只有先买了才能卖。

同理也可以从最后一天开始往前遍历,这时候我们不记录当前所知道的最小price,而是最大值,用最大值减去prices[i]来和max profit比较。代码在这下面。
public int maxProfit(int[] prices) {
        if (prices.length <= 1) {
            return 0;
        }
        int maxProfit = 0;
        int minIndex = 0;
        for(int i = 1; i < prices.length; i++) {
            if (prices[i] < prices[minIndex]) {
                minIndex = i;
            }
            if (prices[i] - prices[minIndex] > maxProfit) {
                maxProfit = prices[i] - prices[minIndex];
            }
        }
        return maxProfit;
    }
然后我们来看如何计算”买卖两次“的最大profit。
因为有了买卖一次的交易算法,我们比较容易去这样想。把整个个prices数组分成两部分,计算前一部分买卖一次的最大值,计算后一部分买卖的最大值,然后求和。然后从0到length重复该操作,求出整个数组上买卖两次的最大值。
不过这样复杂度变成了O(n^2)。
有没有更好的方法呢?
其实这样想,我们在计算买卖一次的遍历过程中,已经有这样的信息了,那就是,在第0天到第i天,买卖一次能得到的最大profit,假设是forward[i]。同理,如果从后面往前遍历的过程中,我们拿到从第i天到最后一天,买卖一次能得到的最大profit,假设是backward[i]。
于是我们最后一步要求的不就是max(forward[i] + backward[i] for i = 0... length)嘛?这样O(n)就能求出来了。
代码如下:
public int maxProfit(int[] prices) {
        int[] maxProfit = new int[prices.length];
        if (prices.length <= 1) {
            return 0;
        }
        //forward
        int minIndex = 0;
        for(int i = 1; i < prices.length; i++) {
            if (prices[i] < prices[minIndex]) {
                minIndex = i;
            }
            maxProfit[i] = Math.max(maxProfit[i], prices[i] - prices[minIndex]);
        }
        //backward
        int maxIndex = prices.length - 1;
        int ret = 0;
        int iMax = 0;
        for(int i = prices.length - 2; i >= 0; i--) {
            if (prices[i] > prices[maxIndex]) {
                maxIndex = i;
            }
            iMax = Math.max(iMax, prices[maxIndex] - prices[i]);
            ret = Math.max(ret, iMax + maxProfit[i]);
        }
        return ret;
    }
注意我们没有使用backward[i],因为第二次遍历直接就能得到max profit了。
LeetCode 笔记23 Best Time to Buy and Sell Stock III的更多相关文章
- 【leetcode】123. Best Time to Buy and Sell Stock III
		@requires_authorization @author johnsondu @create_time 2015.7.22 19:04 @url [Best Time to Buy and Se ... 
- 【刷题-LeetCode】123 Best Time to Buy and Sell Stock III
		Best Time to Buy and Sell Stock III Say you have an array for which the ith element is the price of ... 
- 【LeetCode OJ】Best Time to Buy and Sell Stock III
		Problem Link: http://oj.leetcode.com/problems/best-time-to-buy-and-sell-stock-iii/ Linear Time Solut ... 
- LeetCode OJ 123. Best Time to Buy and Sell Stock III
		Say you have an array for which the ith element is the price of a given stock on day i. Design an al ... 
- 【leetcode刷题笔记】Best Time to Buy and Sell Stock III
		Say you have an array for which the ith element is the price of a given stock on day i. Design an al ... 
- 【LeetCode】123. Best Time to Buy and Sell Stock III 解题报告(Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ... 
- leetcode第一刷_Best Time to Buy and Sell Stock III
		这道题还是挺难的,属于我前面提到的,给个数组,线性时间找出个什么东西,尽管上面的两个买卖股票也是这类.只是相比之下稚嫩多了.有关至少至多的问题比較烦人,不好想,等再做一些题,可能会发现什么规律.这道题 ... 
- 【一天一道LeetCode】#122. Best Time to Buy and Sell Stock II
		一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Say you ... 
- Leetcode之动态规划(DP)专题-123. 买卖股票的最佳时机 III(Best Time to Buy and Sell Stock III)
		Leetcode之动态规划(DP)专题-123. 买卖股票的最佳时机 III(Best Time to Buy and Sell Stock III) 股票问题: 121. 买卖股票的最佳时机 122 ... 
随机推荐
- js 毫秒 转 时间 日期 yyyy-mm-dd hh-mm-ss
			//格式化时间 var format = function(time, format){ var t = new Date(time); var tf = function(i){return (i ... 
- 解决Spring4 MVC请求json数据报406错误
			解决方法一: 1.导入jackson-core-2.5.1.jar和jackson-databind-2.5.1.jar 2.Spring配置文件添加: <!-- 避免IE执行AJAX时,返回J ... 
- centos查看硬件信息
			服务器硬件信息常见, 是经常要操作的事: 下面分享一些常见的硬件查看命令: 1.centos 下查看硬件信息内容非常全面. CentOS常用命令查看cpu more /proc/cpuinfo 2.C ... 
- leveldb源码分析—Recover和Repair
			leveldb作为一个KV存储引擎将数据持久化到磁盘,而对于一个存储引擎来说在存储过程中因为一些其他原因导致程序down掉甚至数据文件被破坏等都会导致程序不能按正常流程再次启动.那么遇到这些状况以后如 ... 
- jquery实践案例--验证手机号码
			如果要做手机号的验证,那么我们需要知道手机号码的号段. 182 183 187 188 155 156 176 186 189 //移动运营商:170 移动: 2G号段(GSM):134-139.15 ... 
- Ubuntu15.04装机配置脚本
			#!/bin/bash echo "vim" sudo apt-get install vim cp -r ./vim/.vim ~/ cp ./vim/.vimrc ~/ ech ... 
- Spring @Transactional ——事务回滚
			工作原理运行配置@Transactional注解的测试类的时候,具体会发生如下步骤1)事务开始时,通过AOP机制,生成一个代理connection对象,并将其放入DataSource实例的某个与Dat ... 
- 《JavaScript修炼之道》读书笔记
			1.参考书目 入门:<JavaScript DOM编程艺术>第二版 进阶:<JavaScript高级程序设计>第二版.<JavaScript编程精粹> <Ja ... 
- Linked List Cycle
			Given a linked list, determine if it has a cycle in it. /** * Definition for singly-linked list. * s ... 
- 关于hadoop 配置文件的一些实验
			机器配置如下,两台机器,nn2,nn2,搭建基于QJM的高可用集群,zk集群. 如果我在yarn-site.xml中配置的nodemanager的可用资源过少,其他配置如果不一致,那么就会造成提交的j ... 
