-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path13_CoinChange_maxWays.cpp
77 lines (63 loc) · 1.82 KB
/
13_CoinChange_maxWays.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
// Question Link :- https://leetcode.com/problems/coin-change-ii/description/
// Coin Change max no. of ways (Coin Change II)
// Similar to [06_count of subset with given sum.cpp]
// T.C = O(n*amount)
// S.C = O(n)
// Approach - 1 (Recursion + Memoization)
// codestorywithMIK
class Solution {
public:
int t[301][5001];
int solve(int i, vector<int>& coins, int n, int amount) {
if(amount == 0) {
return t[i][amount] = 1;
}
if(i == n || amount < 0) {
return 0;
}
if(t[i][amount] != -1) {
return t[i][amount];
}
if(coins[i] > amount) { // skip
return t[i][amount] = solve(i+1, coins, n, amount);
}
int take = solve(i, coins, n, amount-coins[i]);
int skip = solve(i+1, coins, n, amount);
return t[i][amount] = take + skip;
}
int change(int amount, vector<int>& coins) {
int n = coins.size();
memset(t, -1, sizeof(t));
return solve(0, coins, n, amount);
}
};
// Approach - 2 (Tabulation)
// aditya verma
class Solution {
public:
int change(int amount, vector<int>& coins) {
int n = coins.size();
int t[n + 1][amount + 1];
// initialization
for (int i = 0; i <= n; i++) {
for (int j = 0; j <= amount; j++) {
if (i == 0) {
t[i][j] = 0;
}
if (j == 0) {
t[i][j] = 1;
}
}
}
for (int i = 1; i <= n; i++) {
for (int j = 0; j <= amount; j++) { // NOTE :- here j started from 0
if (coins[i - 1] <= j) {
t[i][j] = t[i][j - coins[i - 1]] + t[i - 1][j]; // max ways
} else {
t[i][j] = t[i - 1][j];
}
}
}
return t[n][amount];
}
};