You are given an array prices
where prices[i]
is the price of a given stock on the ith
day, and an integer fee
representing a transaction fee.
Find the maximum profit you can achieve. You may complete as many transactions as you like, but you need to pay the transaction fee for each transaction.
Note:
Example 1:
Input: prices = [1,3,2,8,4,9], fee = 2 Output: 8 Explanation: The maximum profit can be achieved by: - Buying at prices[0] = 1 - Selling at prices[3] = 8 - Buying at prices[4] = 4 - Selling at prices[5] = 9 The total profit is ((8 - 1) - 2) + ((9 - 4) - 2) = 8.
Example 2:
Input: prices = [1,3,7,5,10,3], fee = 3 Output: 6
Constraints:
1 <= prices.length <= 5 * 104
1 <= prices[i] < 5 * 104
0 <= fee < 5 * 104
class Solution {
public:
int helper(vector&prices,int i,int fee,bool buy,vector> &dp)
{
if(i==prices.size())return 0;
if(dp[i][buy]!=-1)return dp[i][buy];
if(buy)
{
int bought=helper(prices,i+1,fee,false,dp)-prices[i]-fee;
int didntBuy=helper(prices,i+1,fee,true,dp);
return dp[i][buy]=max(bought,didntBuy);
}
int sold=helper(prices,i+1,fee,true,dp)+prices[i];
int notSold=helper(prices,i+1,fee,false,dp);
return dp[i][buy]=max(sold,notSold);
}
int maxProfit(vector& prices, int fee) {
vector> dp(prices.size(),vector(2,-1));
return helper(prices,0,fee,true,dp);
}
};
Office:- 660, Sector 14A, Vasundhara, Ghaziabad, Uttar Pradesh - 201012, India