2024-12-10 21:42:26 +00:00
|
|
|
package one
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
)
|
|
|
|
|
2024-12-19 12:54:40 +00:00
|
|
|
const empty = -1
|
|
|
|
|
2024-12-10 21:42:26 +00:00
|
|
|
func Solve(buf []byte) (int, error) {
|
|
|
|
r := bytes.NewReader(buf)
|
2024-12-19 12:54:40 +00:00
|
|
|
expandedRaw, err := parseLines(r)
|
2024-12-10 21:42:26 +00:00
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
2024-12-19 12:54:40 +00:00
|
|
|
disk := newDisk(expandedRaw)
|
|
|
|
disk.reorganise()
|
2024-12-10 21:42:26 +00:00
|
|
|
|
2024-12-19 12:54:40 +00:00
|
|
|
var checksum int
|
|
|
|
for i, n := range disk.data {
|
|
|
|
if n == empty {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
checksum += i * n
|
2024-12-10 21:42:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return checksum, nil
|
|
|
|
}
|