题目大意:给出股票价格数组,最多可以进行两次买卖,求最大收益
分析:类似leetcode121,这道题可以分成两个子问题求解,从i这个位置分成两半,分别求出每一半的最大收益,让两半相加的收益最大的i就是能够取得最终最大利润的位置。
代码:转载自http://blog.sina.com.cn/s/blog_a89440490102x0rj.html
public class Solution {
public int maxProfit(int[] prices) {
if (prices == null || prices.length <= 1) {
return 0;
}
int[] left = new int[prices.length]; //记录i向左的最大收益
int[] right = new int[prices.length]; //记录i向右的最大收益
left[0] = 0;
int min = prices[0];
for (int i = 1; i < prices.length; i++) {
min = Math.min(prices[i], min); //维护最低价格
left[i] = Math.max(left[i - 1], prices[i] - min); //比较之前卖出还是i卖出收益高
}
right[prices.length - 1] = 0;
int max = prices[prices.length - 1];
for (int i = prices.length - 2; i >= 0; i--) {
max = Math.max(prices[i], max);
right[i] = Math.max(right[i + 1], max - prices[i]);
}
int profit = 0;
for (int i = 0; i < prices.length; i++){
profit = Math.max(left[i] + right[i], profit);
}
return profit;
}
}