class Solution {
public int change(int amount, int[] coins) {
int[] dp = new int[amount + 1];
dp[0] = 1;
for (int coin : coins) {
for (int i = coin; i <= amount; i++) {
dp[i] += dp[i-coin];
}
}
return dp[amount];
}
}
- In the general case, our solution may overflow our
int
return value. Can use along
instead.
- Time Complexity: O(amount * coins)
- Space Complexity: O(amount)