aoc2024/day-06/internal/two/solve.go

64 lines
1.2 KiB
Go
Raw Normal View History

2024-12-06 20:01:17 +00:00
package two
import (
"bytes"
"slices"
"github.com/onyx-and-iris/aoc2024/day-06/internal/one"
log "github.com/sirupsen/logrus"
)
func Solve(buf []byte) (int, error) {
r := bytes.NewReader(buf)
graph, err := parseLines(r)
if err != nil {
return 0, err
}
conc := len(one.Visited) - 1
isLoop := make(chan bool)
for loc := range one.Visited {
if loc.X == graph.startPoint.x && loc.Y == graph.startPoint.y {
continue
}
g := newGraph(graph.startPoint, slices.Clone(graph.data))
2024-12-06 20:01:17 +00:00
g.data[loc.Y] = replaceAtIndex(g.data[loc.Y], 'O', loc.X)
p := g.startPoint
go func() {
visited := make(map[point]struct{})
for !(p.x == 0 && p.direction == W ||
p.y == 0 && p.direction == N ||
p.y == len(g.data)-1 && p.direction == S ||
p.x == len(g.data[p.y])-1 && p.direction == E) {
_, ok := visited[p]
if ok {
2024-12-06 20:01:17 +00:00
log.Tracef("loop: \n%s\n", g.trace(visited))
isLoop <- true
return
}
visited[p] = struct{}{}
p = nextPoint(p)
if g.valueAt(p.x, p.y) == '#' || g.valueAt(p.x, p.y) == 'O' {
p.recalibrate()
}
2024-12-06 20:01:17 +00:00
}
isLoop <- false
}()
}
var numLoops int
for range conc {
2025-01-07 17:23:11 +00:00
if <-isLoop {
2024-12-06 20:01:17 +00:00
numLoops++
}
}
return numLoops, nil
}