forked from DengWangBao/Leetcode-Java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCoinChange.java
More file actions
20 lines (18 loc) · 547 Bytes
/
CoinChange.java
File metadata and controls
20 lines (18 loc) · 547 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import java.util.Arrays;
public class CoinChange {
public int coinChange(int[] coins, int amount) {
Arrays.sort(coins);
int[] dp = new int[amount + 1];
Arrays.fill(dp, -1);
dp[0] = 0;
for (int i = 1; i <= amount; i++) {
for (int coin: coins) {
if (i - coin >= 0 && dp[i - coin] >= 0) {
int k = dp[i - coin] + 1;
dp[i] = dp[i] > 0 ? Math.min(dp[i], k) : k;
}
}
}
return dp[amount];
}
}