aoc2024/day-02/internal/two/check.go

33 lines
671 B
Go
Raw Normal View History

2024-12-02 19:28:55 +00:00
package two
import (
"math"
"slices"
)
func withDampener(nums []int, cmp comparator, count int) bool {
2024-12-02 19:28:55 +00:00
if count > 1 {
return false
}
for i := 1; i < len(nums); i++ {
if cmp(nums, i) || !isSafe(nums[i-1], nums[i]) {
2024-12-02 19:28:55 +00:00
count++
removeFirst, removeSecond := nextLevels(nums, i)
return withDampener(removeFirst, cmp, count) ||
withDampener(removeSecond, cmp, count)
2024-12-02 19:28:55 +00:00
}
}
return true
}
func isSafe(m, n int) bool {
return int(math.Abs(float64(m-n))) <= 3
}
func nextLevels(nums []int, i int) ([]int, []int) {
first, second := slices.Clone(nums), slices.Clone(nums)
return append(first[:i-1], first[i:]...), append(second[:i], second[i+1:]...)
}