day two, readme

This commit is contained in:
2023-07-12 09:41:09 -05:00
parent d930d0b5ed
commit dfb70a837b
5 changed files with 139 additions and 46 deletions

77
daytwo.go Normal file
View File

@@ -0,0 +1,77 @@
package main
import (
"fmt"
"strings"
)
func contains(s []string, e string) bool {
for _, a := range s {
if strings.EqualFold(a, e) {
return true
}
}
return false
}
func playValueOf(s string) int {
fmt.Println("played value: " + s)
fmt.Println("last char: " + string(s[len(s)-1]))
switch string(s[len(s)-1]) {
case "Z":
return 3
case "Y":
return 2
case "X":
return 1
default:
panic("Invalid input received at func playValueOf")
}
}
func dayTwo(input string) int {
// split input by newlines
var eachPart = strings.Split(input, "\n")
// trim all remaining whitespace
for j := range eachPart {
eachPart[j] = strings.TrimSpace(eachPart[j])
}
winningResults := []string{
"A Y",
"B Z",
"C X",
}
drawResult := []string{
"A X",
"B Y",
"C Z",
}
losingResult := []string{
"A Z",
"B X",
"C Y",
}
score := 0
for i := 0; i <= 3; i++ {
switch true {
case contains(winningResults, eachPart[i]):
score += playValueOf(eachPart[i]) + 6
case contains(drawResult, eachPart[i]):
score += playValueOf(eachPart[i]) + 3
case contains(losingResult, eachPart[i]):
score += playValueOf(eachPart[i])
default:
score += 0
}
}
return score
}