- 题目
- 示例
- 算法
- 代码
public int maxProfit(int[] prices) {
int n = prices.length;
int[][] dp = new int[n][2];
dp[0][1] = -prices[0];
for (int i = 1; i < n; i++) {
dp[i][0] = Math.max(dp[i-1][0], dp[i-1][1] + prices[i]);
dp[i][1] = Math.max(dp[i-1][1], dp[i-1][0] - prices[i]);
}
return dp[n-1][0];
}
- 算法
- 代码
public int maxProfit(int[] prices) {
int res = 0;
for (int i = 0; i + 1 < prices.length; i++) {
res += Math.max(prices[i+1] - prices[i], 0);
}
return res;
}