文章目录
题目
思路
两次动态规划,第一次动态规划从前到后,第二次从后到前,然后在前后两次动态规划的结果和中找到最大值即可。
代码实现(Java)
class Solution {
public int maxProfit(int[] prices) {
int max = 0, len = prices.length;
int[] before = new int[len];
int[] after = new int[len];
before[0] = -prices[0];
int min = prices[0];
for(int i = 1; i<len; i++) {
before[i] = Math.max(before[i-1],prices[i]-min);
min = Math.min(min,prices[i]);
}
int maxValue = prices[len-1];
for(int i = len-2; i>=0; i--) {
after[i] = Math.max(after[i+1],maxValue - prices[i]);
maxValue = Math.max(maxValue,prices[i]);
}
for(int i = 1; i<=len-1; i++) {
max = Math.max(before[i-1] + after[i] , max);
}
return Math.max(before[len-1],max);
}
}
坚持分享,坚持原创,喜欢博主的靓仔靓女们可以看看博主的首页博客!
您的点赞与收藏是我分享博客的最大赞赏!
博主博客地址: https://blog.youkuaiyun.com/weixin_43967679