-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday12_1.go
48 lines (39 loc) · 1.04 KB
/
day12_1.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
package day12
import (
"strings"
"github.com/blfuentes/AdventOfCode_2024_Go/utilities"
)
func calculatePerimeter(points []Coord, maxRows, maxCols int) (perimeter int) {
processed := make(map[Coord]struct{})
for _, p := range points {
if _, ok := processed[p]; !ok {
processed[p] = struct{}{}
}
}
for _, point := range points {
for _, n := range neighbours(point) {
if !utilities.IsInBoundaries(n.Row, n.Col, maxRows, maxCols) {
perimeter++
} else if _, ok := processed[n]; !ok {
perimeter++
}
}
}
return
}
func Executepart1() int {
var result int = 0
var fileName string = "./day12/day12.txt"
if fileContent, err := utilities.ReadFileAsLines(fileName); err == nil {
garden := make([][]string, 0)
for _, line := range fileContent {
garden = append(garden, strings.Split(line, ""))
}
maxRows, maxCols := len(garden), len(garden[0])
regions := buildRegions(garden, maxRows, maxCols)
for _, reg := range regions {
result += reg.Size * calculatePerimeter(reg.Points, maxRows, maxCols)
}
}
return result
}