mirror of
https://github.com/onyx-and-iris/aoc2024.git
synced 2025-01-09 14:20:48 +00:00
move file parsing into util.go
This commit is contained in:
parent
f6eeece8d7
commit
a4e8e83844
@ -1,11 +1,7 @@
|
|||||||
package one
|
package one
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"io"
|
|
||||||
"slices"
|
|
||||||
"strconv"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const empty = -1
|
const empty = -1
|
||||||
@ -30,41 +26,3 @@ func Solve(buf []byte) (int, error) {
|
|||||||
|
|
||||||
return checksum, nil
|
return checksum, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseLines(r io.Reader) ([]int, error) {
|
|
||||||
var line string
|
|
||||||
scanner := bufio.NewScanner(r)
|
|
||||||
for scanner.Scan() {
|
|
||||||
line = scanner.Text()
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := scanner.Err(); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
raw := [][]int{}
|
|
||||||
for i, id := 0, 0; i < len(line); i, id = i+2, id+1 {
|
|
||||||
raw = append(raw, []int{id, mustConv(string(line[i]))})
|
|
||||||
var free int
|
|
||||||
if i < len(line)-1 {
|
|
||||||
free = mustConv(string(line[i+1]))
|
|
||||||
}
|
|
||||||
raw = append(raw, []int{empty, free})
|
|
||||||
}
|
|
||||||
|
|
||||||
expandedRaw := []int{}
|
|
||||||
for _, vals := range raw {
|
|
||||||
segment := slices.Repeat([]int{vals[0]}, vals[1])
|
|
||||||
expandedRaw = append(expandedRaw, segment...)
|
|
||||||
}
|
|
||||||
|
|
||||||
return expandedRaw, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func mustConv(s string) int {
|
|
||||||
n, err := strconv.Atoi(s)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return n
|
|
||||||
}
|
|
||||||
|
46
day-09/internal/one/util.go
Normal file
46
day-09/internal/one/util.go
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
package one
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"io"
|
||||||
|
"slices"
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
func parseLines(r io.Reader) ([]int, error) {
|
||||||
|
var line string
|
||||||
|
scanner := bufio.NewScanner(r)
|
||||||
|
for scanner.Scan() {
|
||||||
|
line = scanner.Text()
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := scanner.Err(); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
raw := [][]int{}
|
||||||
|
for i, id := 0, 0; i < len(line); i, id = i+2, id+1 {
|
||||||
|
raw = append(raw, []int{id, mustConv(string(line[i]))})
|
||||||
|
var free int
|
||||||
|
if i < len(line)-1 {
|
||||||
|
free = mustConv(string(line[i+1]))
|
||||||
|
}
|
||||||
|
raw = append(raw, []int{empty, free})
|
||||||
|
}
|
||||||
|
|
||||||
|
expandedRaw := []int{}
|
||||||
|
for _, vals := range raw {
|
||||||
|
segment := slices.Repeat([]int{vals[0]}, vals[1])
|
||||||
|
expandedRaw = append(expandedRaw, segment...)
|
||||||
|
}
|
||||||
|
|
||||||
|
return expandedRaw, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func mustConv(s string) int {
|
||||||
|
n, err := strconv.Atoi(s)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return n
|
||||||
|
}
|
@ -1,11 +1,7 @@
|
|||||||
package two
|
package two
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"io"
|
|
||||||
"slices"
|
|
||||||
"strconv"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const empty = -1
|
const empty = -1
|
||||||
@ -32,41 +28,3 @@ func Solve(buf []byte) (int, error) {
|
|||||||
|
|
||||||
return sum, nil
|
return sum, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseLines(r io.Reader) ([]int, error) {
|
|
||||||
var line string
|
|
||||||
scanner := bufio.NewScanner(r)
|
|
||||||
for scanner.Scan() {
|
|
||||||
line = scanner.Text()
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := scanner.Err(); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
raw := [][]int{}
|
|
||||||
for i, id := 0, 0; i < len(line); i, id = i+2, id+1 {
|
|
||||||
raw = append(raw, []int{id, mustConv(string(line[i]))})
|
|
||||||
var free int
|
|
||||||
if i < len(line)-1 {
|
|
||||||
free = mustConv(string(line[i+1]))
|
|
||||||
}
|
|
||||||
raw = append(raw, []int{empty, free})
|
|
||||||
}
|
|
||||||
|
|
||||||
expandedRaw := []int{}
|
|
||||||
for _, vals := range raw {
|
|
||||||
segment := slices.Repeat([]int{vals[0]}, vals[1])
|
|
||||||
expandedRaw = append(expandedRaw, segment...)
|
|
||||||
}
|
|
||||||
|
|
||||||
return expandedRaw, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func mustConv(s string) int {
|
|
||||||
n, err := strconv.Atoi(s)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return n
|
|
||||||
}
|
|
||||||
|
46
day-09/internal/two/util.go
Normal file
46
day-09/internal/two/util.go
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
package two
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"io"
|
||||||
|
"slices"
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
func parseLines(r io.Reader) ([]int, error) {
|
||||||
|
var line string
|
||||||
|
scanner := bufio.NewScanner(r)
|
||||||
|
for scanner.Scan() {
|
||||||
|
line = scanner.Text()
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := scanner.Err(); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
raw := [][]int{}
|
||||||
|
for i, id := 0, 0; i < len(line); i, id = i+2, id+1 {
|
||||||
|
raw = append(raw, []int{id, mustConv(string(line[i]))})
|
||||||
|
var free int
|
||||||
|
if i < len(line)-1 {
|
||||||
|
free = mustConv(string(line[i+1]))
|
||||||
|
}
|
||||||
|
raw = append(raw, []int{empty, free})
|
||||||
|
}
|
||||||
|
|
||||||
|
expandedRaw := []int{}
|
||||||
|
for _, vals := range raw {
|
||||||
|
segment := slices.Repeat([]int{vals[0]}, vals[1])
|
||||||
|
expandedRaw = append(expandedRaw, segment...)
|
||||||
|
}
|
||||||
|
|
||||||
|
return expandedRaw, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func mustConv(s string) int {
|
||||||
|
n, err := strconv.Atoi(s)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return n
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user