chore: add day16
This commit is contained in:
parent
b97ecdc93c
commit
e742db7ec9
37
tools.go
37
tools.go
|
@ -2,6 +2,7 @@ package aoc
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
|
"cmp"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -88,13 +89,7 @@ func LCM[T integer](integers ...T) T {
|
||||||
}
|
}
|
||||||
|
|
||||||
func ReadStringToInts(fields []string) []int {
|
func ReadStringToInts(fields []string) []int {
|
||||||
arr := make([]int, len(fields))
|
return SliceMap(Atoi, fields...)
|
||||||
for i, s := range fields {
|
|
||||||
if v, err := strconv.Atoi(s); err == nil {
|
|
||||||
arr[i] = v
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return arr
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type Node[T any] struct {
|
type Node[T any] struct {
|
||||||
|
@ -214,8 +209,8 @@ func Atoi(s string) int {
|
||||||
return i
|
return i
|
||||||
}
|
}
|
||||||
|
|
||||||
func Repeat(s string, i int) []string {
|
func Repeat[T any](s T, i int) []T {
|
||||||
lis := make([]string, i)
|
lis := make([]T, i)
|
||||||
for i := range lis {
|
for i := range lis {
|
||||||
lis[i] = s
|
lis[i] = s
|
||||||
}
|
}
|
||||||
|
@ -229,14 +224,17 @@ func Sum[T integer](arr ...T) T {
|
||||||
}
|
}
|
||||||
return acc
|
return acc
|
||||||
}
|
}
|
||||||
func SumFunc[T any,U integer](fn func(T) U, input ...T) U {
|
func SumFunc[T any, U integer](fn func(T) U, input ...T) U {
|
||||||
return Sum(SliceMap(fn, input...)...)
|
return Sum(SliceMap(fn, input...)...)
|
||||||
}
|
}
|
||||||
func SumIFunc[T any,U integer](fn func(int, T) U, input ...T) U {
|
func SumIFunc[T any, U integer](fn func(int, T) U, input ...T) U {
|
||||||
return Sum(SliceIMap(fn, input...)...)
|
return Sum(SliceIMap(fn, input...)...)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Power2(n int) int {
|
func Power2(n int) int {
|
||||||
|
if n == 0 {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
p := 2
|
p := 2
|
||||||
for ; n > 1; n-- {
|
for ; n > 1; n-- {
|
||||||
p *= 2
|
p *= 2
|
||||||
|
@ -273,3 +271,20 @@ func Reduce[T, U any](fn func(int, T, U) U, u U, list ...T) U {
|
||||||
}
|
}
|
||||||
return u
|
return u
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Max[T cmp.Ordered](a T, v ...T) T {
|
||||||
|
for _, b := range v {
|
||||||
|
if b > a {
|
||||||
|
a = b
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return a
|
||||||
|
}
|
||||||
|
func Min[T cmp.Ordered](a T, v ...T) T {
|
||||||
|
for _, b := range v {
|
||||||
|
if b < a {
|
||||||
|
a = b
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return a
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user