day 9 part 1

This commit is contained in:
Araozu 2024-04-27 19:38:37 -05:00
parent 0042d2fbcd
commit 6260392b4e
2 changed files with 63 additions and 0 deletions

View File

@ -30,6 +30,9 @@ func main() {
runAndBenchmark("08", "1", false, solutions.Day08Part01)
runAndBenchmark("08", "2", false, solutions.Day08Part02)
runAndBenchmark("09", "1", false, solutions.Day09Part01)
runAndBenchmark("09", "2", true, solutions.Day09Part02)
}
type execute func(bool) int

60
solutions/day09.go Normal file
View File

@ -0,0 +1,60 @@
package solutions
import (
"strconv"
"strings"
)
func Day09Part01(isTest bool) int {
input := ReadInput("09", isTest)
groups := strings.Split(input, "\n")
dataSize := len(groups)
numbers := make([]int, dataSize)
for i, str := range groups {
value, err := strconv.Atoi(str)
if err != nil {
panic(err)
}
numbers[i] = value
}
// loop
preambleSize := 25
out:
for i := 0; i < dataSize-preambleSize; i += 1 {
sum := numbers[i+preambleSize]
// A slice that stores: sum - i
indexes := make([]int, preambleSize)
// Iterate over every `preambleSize` items
for j := 0; j < preambleSize; j += 1 {
number := numbers[j+i]
// On every iteration check if the current value is present in indexes
for _, value := range indexes {
// If so, a pair is found
if value == number {
continue out
}
}
indexes = append(indexes, sum-number)
}
// When this is reached no sum was found
return sum
}
return -1
}
func Day09Part02(isTest bool) int {
// input := ReadInput("09", isTest)
// groups := strings.Split(input, "\n")
return -1
}