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

44 lines
759 B
Go

package one
import (
"bufio"
"bytes"
"io"
"math"
"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 sum int
for i, n := range left {
sum += int(math.Abs(float64(n - right[i])))
}
return sum, nil
}
func parseLines(r io.Reader) ([]int, []int, error) {
var left, right []int
scanner := bufio.NewScanner(r)
for scanner.Scan() {
nums := strings.Fields(scanner.Text())
left = util.InsertSorted(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
}