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

52 lines
1.1 KiB
Go
Raw Permalink Normal View History

2024-12-06 20:01:17 +00:00
package one
import (
"bytes"
log "github.com/sirupsen/logrus"
)
var Visited = make(map[coords]struct{})
func Solve(buf []byte) (int, error) {
r := bytes.NewReader(buf)
graph, err := parseLines(r)
if err != nil {
return 0, err
}
log.Debug(graph.startPoint.String())
var count int
2025-01-07 17:23:11 +00:00
count = nextStep(graph.startPoint, Visited, count, graph)
2024-12-06 20:01:17 +00:00
log.Debugf("path walked: \n%s\n", graph.debug(Visited))
return count, nil
}
2025-01-07 17:23:11 +00:00
func nextStep(point point, visited map[coords]struct{}, count int, g *graph) int {
2024-12-06 20:01:17 +00:00
_, ok := visited[point.coords]
if !ok {
visited[point.coords] = struct{}{}
count++
}
log.Debugf("count: %d\n", count)
if point.X == 0 && point.direction == W ||
point.Y == 0 && point.direction == N ||
2025-01-07 17:23:11 +00:00
point.Y == len(g.data)-1 && point.direction == S ||
point.X == len(g.data[point.Y])-1 && point.direction == E {
2024-12-06 20:01:17 +00:00
return count
}
next := nextPoint(point)
log.Debug(next.String())
2025-01-07 17:23:11 +00:00
log.Debug(string(g.data[next.Y][next.X]))
if g.data[next.Y][next.X] == '#' {
2024-12-06 20:01:17 +00:00
next.recalibrate()
log.Debugf("switched direction to %d", next.direction)
}
2025-01-07 17:23:11 +00:00
return nextStep(next, visited, count, g)
2024-12-06 20:01:17 +00:00
}