leetcode 188. 买卖股票的最佳时机 IV

本质和买卖股票的最佳时机3一样。
class Solution {
public int maxProfit(int k, int[] prices) {
int len=prices.length;
if(len==0||k==0) return 0;
int k2=k*2;
int[] dp=new int[k2];
for(int i=0;i<k2;i+=2){
dp[i]=-prices[0];
}
for(int i=1;i<len;i++){
dp[0]=Math.max(dp[0],-prices[i]);
dp[1]=Math.max(dp[1],dp[0]+prices[i]);
for(int j=2;j<k2;j+=2){
dp[j]=Math.max(dp[j],dp[j-1]-prices[i]);
dp[j+1]=Math.max(dp[j+1],dp[j]+prices[i]);
}
}
return dp[k2-1];
}
}

浙公网安备 33010602011771号