Skip to content

Commit

Permalink
2022 Day 1 part 2
Browse files Browse the repository at this point in the history
  • Loading branch information
psa committed Dec 6, 2022
1 parent a1cff5e commit b840bed
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 12 deletions.
40 changes: 28 additions & 12 deletions 2022/1/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (
"fmt"
"io/ioutil"
"os"
"sort"
"strconv"
"strings"
)
Expand All @@ -30,16 +31,6 @@ func readFile(filename string) ([]string, error) {
return lines, nil
}

func findHeaviestLoad(food []int) int {
heaviest := 0
for _, load := range food {
if load > heaviest {
heaviest = load
}
}
return heaviest
}

func calculateLoads(food []string) ([]int, error) {
var loads []int
var currentLoad int
Expand All @@ -63,6 +54,29 @@ func calculateLoads(food []string) ([]int, error) {
return loads, nil
}

func findHeaviestLoad(food []int) int {
heaviest := 0
for _, load := range food {
if load > heaviest {
heaviest = load
}
}
return heaviest
}

func findTopThreeTotal(food []int) (int, error) {
total := 0
sort.Ints(food)
if len(food) < 3 {
return -1, errors.New("Not enough elves, need minimum of 3")
}
lastThree := food[len(food)-3:]
for _, i := range lastThree {
total += i
}
return total, nil
}

func main() {
var fileName string
var part2 bool
Expand All @@ -85,8 +99,10 @@ func main() {
if !part2 {
result = findHeaviestLoad(loads)
} else {
result = findHeaviestLoad(loads)
result, err = findTopThreeTotal(loads)
if nil != err {
die(err)
}
}

fmt.Println(result)
}
15 changes: 15 additions & 0 deletions 2022/1/main_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -168,3 +168,18 @@ func TestCalculateLoadsErrors(t *testing.T) {
t.Fail()
}
}

func TestFindTopThreeTotal(t *testing.T) {
data := []int{0, 2, 6, 3, 4}
var result int
var err error
result, err = findTopThreeTotal(data)
if nil != err {
t.Log("Unexpected error:", err)
t.Fail()
}
if result != 13 {
t.Log("Expected 13, got:", result)
t.Fail()
}
}

0 comments on commit b840bed

Please sign in to comment.