-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy path0518-coin-change-ii.cpp
92 lines (78 loc) · 4.55 KB
/
0518-coin-change-ii.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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
Problem: LeetCode 518 - Coin Change 2
Description:
You are given an integer array coins representing coins of different denominations and an integer amount representing a total amount of money.
Return the number of combinations that make up that amount.
You may assume that you have an infinite number of each kind of coin.
The answer is guaranteed to fit into a signed 32-bit integer.
Intuition:
To find the number of combinations that make up the amount, we can use dynamic programming.
At each step, we can decide whether to include a coin or not.
The key idea is to track the number of combinations for each amount up to the target amount.
Approach:
1. Initialize a 1D array dp of size (amount + 1) and set dp[0] = 1, representing the base case where there is one way to make up an amount of 0.
2. Iterate through the coins array:
- For each coin, iterate through the amounts from coin to the target amount:
- Update the dp[j] by adding the number of combinations for the amount j - coin.
3. Return dp[amount], which represents the number of combinations that make up the target amount.
Time Complexity:
The time complexity is O(coins * amount), where coins is the number of coins and amount is the target amount.
Space Complexity:
The space complexity is O(amount) as we only need a 1D array to store the number of combinations.
Dynamic Programming:
- Subproblem: The subproblem is finding the number of combinations for each amount up to the target amount.
- Recurrence Relation: dp[j] = dp[j] + dp[j - coin], where dp[j] represents the number of combinations for the amount j.
- Base Case: Initialize dp[0] = 1, representing one way to make up an amount of 0.
*/
class Solution {
public:
int change(int amount, vector<int> &coins) {
// Create a DP array to store the number of combinations
// dp[i] represents the number of combinations to make amount i
vector<int> dp(amount + 1, 0);
// Base case: There is one combination to make amount 0, using no coins
dp[0] = 1;
// Iterate over the coins
for (int coin : coins) {
// For each coin, iterate over the amounts starting from the coin value
for (int i = coin; i <= amount; ++i) {
// For each amount, add the number of combinations from the current amount minus the coin value
// This accounts for using the current coin to make the remaining amount
// We sum up these combinations for all the coins to get the total number of combinations for the current amount
dp[i] += dp[i - coin];
}
}
// Return the number of combinations to make the given amount using the coins
return dp[amount];
}
};
// class Solution {
// public:
// int change(int amount, vector<int>& coins) {
// // Create a 2D DP array to store the number of combinations
// // dp[i][j] represents the number of combinations to make amount j using coins up to the ith index
// vector<vector<int>> dp(coins.size() + 1, vector<int>(amount + 1, 0));
// // Base case: There is one combination to make amount 0, using no coins
// dp[0][0] = 1;
// // Iterate over the coins
// for (int i = 1; i <= coins.size(); ++i) {
// // For the first column (amount = 0), there is one combination for each coin, i.e., not selecting the coin
// dp[i][0] = 1;
// for (int j = 1; j <= amount; ++j) {
// // If the current coin value is less than or equal to the current amount, we have two options:
// // 1. Use the current coin by subtracting its value from the amount (j) and considering the number of combinations from the same row (coin)
// // 2. Skip the current coin and consider the number of combinations from the previous row (coin - 1) for the same amount (j)
// // We sum up these two options to get the total number of combinations
// if (coins[i - 1] <= j) {
// dp[i][j] = dp[i][j - coins[i - 1]] + dp[i - 1][j];
// } else {
// // If the current coin value is greater than the current amount, we cannot include it in the combination
// // So, we only consider the number of combinations from the previous row for the same amount
// dp[i][j] = dp[i - 1][j];
// }
// }
// }
// // Return the number of combinations to make the given amount using all the coins
// return dp[coins.size()][amount];
// }
// };