mirror of
https://github.com/onyx-and-iris/aoc2024.git
synced 2025-01-10 14:50:46 +00:00
56 lines
898 B
Go
56 lines
898 B
Go
package two
|
|
|
|
import (
|
|
"bufio"
|
|
"bytes"
|
|
"io"
|
|
"slices"
|
|
"strings"
|
|
|
|
"github.com/onyx-and-iris/aoc2024/day-01/internal/util"
|
|
)
|
|
|
|
func Solve(data []byte) (int, error) {
|
|
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
|
|
}
|
|
|
|
for i, n := range right[indx:] {
|
|
if n > k {
|
|
similarity += k * v * i
|
|
break
|
|
}
|
|
}
|
|
}
|
|
|
|
return similarity, nil
|
|
}
|
|
|
|
func parseLines(r io.Reader) (map[int]int, []int, error) {
|
|
left := make(map[int]int)
|
|
right := []int{}
|
|
|
|
scanner := bufio.NewScanner(r)
|
|
for scanner.Scan() {
|
|
nums := strings.Fields(scanner.Text())
|
|
|
|
left[util.MustConv(nums[0])]++
|
|
right = util.InsertSorted(right, util.MustConv(nums[1]))
|
|
}
|
|
|
|
if err := scanner.Err(); err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
return left, right, nil
|
|
}
|