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

65 lines
1.1 KiB
Go
Raw Normal View History

2024-12-01 17:50:02 +00:00
package two
import (
"bufio"
"bytes"
"embed"
"io"
"regexp"
"slices"
"github.com/onyx-and-iris/aoc2024/day-01/internal/util"
)
//go:embed testdata
var files embed.FS
var reNums = regexp.MustCompile(`[0-9]+`)
func Solve() (int, error) {
data, _ := files.ReadFile("testdata/input.txt")
r := bytes.NewReader(data)
left, right, err := parseLines(r)
if err != nil {
return 0, err
}
var similarity int
for k, v := range left {
indx := slices.Index(right, k)
if indx == -1 {
continue
}
var occurrences int
for _, n := range right[indx:] {
if n > k {
break
2024-12-01 17:50:02 +00:00
}
occurrences++
2024-12-01 17:50:02 +00:00
}
similarity += k * v * occurrences
}
return similarity, nil
}
func parseLines(r io.Reader) (map[int]int, []int, error) {
var left map[int]int = make(map[int]int)
var right []int
scanner := bufio.NewScanner(r)
for scanner.Scan() {
nums := reNums.FindAllString(scanner.Text(), -1)
left[util.MustConv(nums[0])] = left[util.MustConv(nums[0])] + 1
right = util.InsertSorted(right, util.MustConv(nums[1]))
}
if err := scanner.Err(); err != nil {
return nil, nil, err
}
return left, right, nil
}