-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBest Time To Buy And Sell Stock III.cpp
58 lines (53 loc) Β· 1.49 KB
/
Best Time To Buy And Sell Stock III.cpp
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
55
56
57
58
/*
class Solution {
public:
int maxProfit(vector<int>& prices) {
}
};
*/
class Solution {
public:
/////// MEMOIZATION
// int f(int ind,int buy, int cap ,int n ,vector<int>&v,vector<vector<vector<int>>> &dp){
// int notpick,pick;
// if(ind==n) return 0;
// if(cap == 0) return 0;
// if(dp[ind][buy][cap] != -1 ) return dp[ind][buy][cap];
// if(buy){
// notpick = 0 + f(ind+1,1,cap,n,v,dp);
// pick = v[ind] + f(ind+1,0,cap-1,n,v,dp);
// }
// else{
// notpick = 0 + f(ind+1,0,cap,n,v,dp);
// pick = -v[ind] + f(ind+1,1,cap,n,v,dp);
// }
// return dp[ind][buy][cap] = max(pick,notpick);
// }
// int maxProfit(vector<int>&v){
// int n = v.size();
// vector<vector<vector<int>>> dp (n,vector<vector<int>>(2,vector<int>(3,-1)));
// return f(0,0,2,n,v,dp);
// }
///////// TABULATION
int maxProfit(vector<int>&v){
int n = v.size();
int notpick,pick;
vector<vector<vector<int>>> dp (n+1,vector<vector<int>>(2,vector<int>(3,0)));
for(int i=n-1;i>=0;i--){
for(int j=0;j<=1;j++){
for(int k=1;k<=2;k++){
if(j){
notpick = 0 + dp[i+1][1][k];
pick = v[i] + dp[i+1][0][k-1];
}
else{
notpick = 0 + dp[i+1][0][k];
pick = -v[i] + dp[i+1][1][k];
}
dp[i][j][k] = max(pick,notpick);
}
}
}
return dp[0][0][2];
}
};