generated from devries/aoc_template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsolution.go
72 lines (57 loc) · 1.19 KB
/
solution.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
72
package day21p1
import (
"io"
"aoc/utils"
)
func Solve(r io.Reader) any {
return solveSteps(r, 64)
}
func solveSteps(r io.Reader, steps int) int {
lines := utils.ReadLines(r)
garden := Maze{make(map[utils.Point]rune), utils.NewBFS[utils.Point](), steps}
for j, ln := range lines {
for i, r := range ln {
p := utils.Point{X: i, Y: -j}
garden.positions[p] = r
}
}
_, err := garden.bfs.Run(garden)
if err != utils.BFSNotFound {
panic("this should end when points are exhausted")
}
count := 0
for _, d := range garden.bfs.Distance {
if d%2 == 0 {
count++
}
}
return count
}
type Maze struct {
positions map[utils.Point]rune
bfs *utils.BreadthFirstSearch[utils.Point]
steps int
}
func (m Maze) GetInitial() utils.Point {
for k, v := range m.positions {
if v == 'S' {
return k
}
}
panic("unable to find starting point")
}
func (m Maze) GetNeighbors(pos utils.Point) []utils.Point {
ret := []utils.Point{}
if m.bfs.Distance[pos] < uint64(m.steps) {
for _, dir := range utils.Directions {
np := pos.Add(dir)
if m.positions[np] == '.' {
ret = append(ret, np)
}
}
}
return ret
}
func (m Maze) IsFinal(pos utils.Point) bool {
return false
}