package two import ( "bufio" "bytes" "io" "slices" "strings" "github.com/onyx-and-iris/aoc2024/day-01/internal/util" ) func Solve(buf []byte) (int, error) { r := bytes.NewReader(buf) 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 }