forked from algorithmzuo/algorithm-journey
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCode06_Stack6.java
More file actions
54 lines (50 loc) · 1.89 KB
/
Code06_Stack6.java
File metadata and controls
54 lines (50 loc) · 1.89 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
package class082;
// 买卖股票的最佳时机含冷冻期
// 给定一个整数数组prices,其中第 prices[i] 表示第 i 天的股票价格
// 设计一个算法计算出最大利润
// 在满足以下约束条件下,你可以尽可能地完成更多的交易(多次买卖一支股票):
// 卖出股票后,你无法在第二天买入股票 (即冷冻期为 1 天)
// 注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)
// 测试链接 : https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-with-cooldown/
public class Code06_Stack6 {
public static int maxProfit1(int[] prices) {
int n = prices.length;
if (n < 2) {
return 0;
}
// prepare[i] : 0...i范围上,可以做无限次交易,获得收益的同时一定要扣掉一次购买,所有情况中的最好情况
int[] prepare = new int[n];
// done[i] : 0...i范围上,可以做无限次交易,能获得的最大收益
int[] done = new int[n];
prepare[1] = Math.max(-prices[0], -prices[1]);
done[1] = Math.max(0, prices[1] - prices[0]);
for (int i = 2; i < n; i++) {
done[i] = Math.max(done[i - 1], prepare[i - 1] + prices[i]);
prepare[i] = Math.max(prepare[i - 1], done[i - 2] - prices[i]);
}
return done[n - 1];
}
// 只是把方法1做了变量滚动更新(空间压缩)
// 并没有新的东西
public static int maxProfit2(int[] prices) {
int n = prices.length;
if (n < 2) {
return 0;
}
// prepare : prepare[i-1]
int prepare = Math.max(-prices[0], -prices[1]);
// done2 : done[i-2]
int done2 = 0;
// done1 : done[i-1]
int done1 = Math.max(0, prices[1] - prices[0]);
for (int i = 2, curDone; i < n; i++) {
// curDone : done[i]
curDone = Math.max(done1, prepare + prices[i]);
// prepare : prepare[i-1] -> prepare[i]
prepare = Math.max(prepare, done2 - prices[i]);
done2 = done1;
done1 = curDone;
}
return done1;
}
}