mirror of
https://github.com/onyx-and-iris/aoc2024.git
synced 2025-01-10 06:40:47 +00:00
49 lines
808 B
Go
49 lines
808 B
Go
|
package two
|
||
|
|
||
|
import (
|
||
|
"slices"
|
||
|
"strings"
|
||
|
)
|
||
|
|
||
|
type point struct {
|
||
|
x int
|
||
|
y int
|
||
|
}
|
||
|
|
||
|
func newPoint(x, y int) point {
|
||
|
return point{x, y}
|
||
|
}
|
||
|
|
||
|
type graph struct {
|
||
|
data []string
|
||
|
}
|
||
|
|
||
|
func newGraph() *graph {
|
||
|
return &graph{}
|
||
|
}
|
||
|
|
||
|
func (g *graph) String() string {
|
||
|
return strings.Join(g.data, "\n")
|
||
|
}
|
||
|
|
||
|
func (g *graph) isOutOfBounds(p point) bool {
|
||
|
return p.x < 0 || p.y < 0 || p.y >= len(g.data) || p.x >= len(g.data[p.y])
|
||
|
}
|
||
|
|
||
|
func (g *graph) valueAt(p point) rune {
|
||
|
return rune(g.data[p.y][p.x])
|
||
|
}
|
||
|
|
||
|
func (g *graph) sameKind(p, q point) bool {
|
||
|
return g.valueAt(p) == g.valueAt(q)
|
||
|
}
|
||
|
|
||
|
func (g *graph) debug(visited map[point]struct{}) *graph {
|
||
|
temp := newGraph()
|
||
|
temp.data = slices.Clone(g.data)
|
||
|
for point := range visited {
|
||
|
temp.data[point.y] = replaceAtIndex(temp.data[point.y], -1, point.x)
|
||
|
}
|
||
|
return temp
|
||
|
}
|