forked from loiane/javascript-datastructures-algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmin-coin-change.ts
34 lines (32 loc) · 877 Bytes
/
min-coin-change.ts
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
export function minCoinChange(coins: number[], amount: number) {
const cache: Array<Array<number>> = [];
// tslint:disable-next-line:no-shadowed-variable
const makeChange = function(amount: number) {
if (!amount) {
return [];
}
if (cache[amount]) {
return cache[amount];
}
let min: number[] = [],
newMin,
newAmount;
for (let i = 0; i < coins.length; i++) {
const coin = coins[i];
newAmount = amount - coin;
if (newAmount >= 0) {
newMin = makeChange(newAmount);
}
if (
newAmount >= 0 &&
(newMin.length < min.length - 1 || !min.length) &&
(newMin.length || !newAmount)
) {
min = [coin].concat(newMin);
// console.log('new Min ' + min + ' for ' + amount);
}
}
return (cache[amount] = min);
};
return makeChange(amount);
}