-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy pathatm.go
71 lines (55 loc) · 1.41 KB
/
atm.go
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
package main
import (
"bufio"
"fmt"
"os"
"strconv"
"strings"
)
func main() {
scanner := bufio.NewScanner(os.Stdin)
var line string
// читаем сумму, которую нужно набрать
var m int
scanner.Scan()
line = scanner.Text()
m, _ = strconv.Atoi(line)
// читаем количество монет в банкомате
var n int
scanner.Scan()
line = scanner.Text()
n, _ = strconv.Atoi(line)
// читаем достоинства монет
coins := make([]int, n+1)
scanner.Scan()
line = scanner.Text()
values := strings.Split(line, " ")
var value int
for i := 0; i < n; i++ {
value, _ = strconv.Atoi(values[i])
coins[i+1] = value
}
/*
dp[i][j] - число способов набрать сумму j, используя первые i монет
*/
dp := make([][]int, n+1)
for i := range dp {
dp[i] = make([]int, m+1)
}
// базовый случай
for i := 1; i <= n; i++ {
dp[i][0] = 1 // вернуть 0 монет можно только одним способом - ничего не возвращать
}
// Динамика: dp[s][n] = dp[s][n - max(s)] + dp[s-max[s]][n]
// https://www.youtube.com/watch?v=GrG1u1xbqhs&ab_channel=EvgeniyMalov
for i := 1; i <= n; i++ {
for j := 1; j <= m; j++ {
if j-coins[i] >= 0 {
dp[i][j] = dp[i][j-coins[i]] + dp[i-1][j]
} else {
dp[i][j] = dp[i-1][j]
}
}
}
fmt.Print(dp[n][m])
}