mirror of
https://github.com/onyx-and-iris/aoc2024.git
synced 2025-01-10 14:50:46 +00:00
37 lines
766 B
Go
37 lines
766 B
Go
package two
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/onyx-and-iris/aoc2024/day-08/internal/util"
|
|
)
|
|
|
|
type graph struct {
|
|
data []string
|
|
antennae []antenna
|
|
antinodes antiNodeCache
|
|
}
|
|
|
|
func newGraph() *graph {
|
|
return &graph{antinodes: newAntiNodeCache()}
|
|
}
|
|
|
|
func (g *graph) String() string {
|
|
return strings.Join(g.data, "\n")
|
|
}
|
|
|
|
func (g *graph) isOutOfBounds(c coords) bool {
|
|
return c.x < 0 || c.y < 0 || c.y >= len(g.data) || c.x >= len(g.data[0])
|
|
}
|
|
|
|
func (g *graph) debug() string {
|
|
for _, antenna := range g.antennae {
|
|
g.data[antenna.y] = util.ReplaceAtIndex(g.data[antenna.y], antenna.identifier, antenna.x)
|
|
}
|
|
for antinode := range g.antinodes.data {
|
|
g.data[antinode.y] = util.ReplaceAtIndex(g.data[antinode.y], '#', antinode.x)
|
|
}
|
|
|
|
return g.String()
|
|
}
|