Add day 6 part 2

This commit is contained in:
Nick Krichevsky 2023-12-06 08:02:37 -05:00
parent bc06bdaa44
commit 89112a526f

View file

@ -46,12 +46,28 @@ func main() {
} }
fmt.Printf("Part 1: %d\n", part1(races)) fmt.Printf("Part 1: %d\n", part1(races))
// fmt.Printf("Part 2: %d\n", part2(seeds, conversions, workSize)) fmt.Printf("Part 2: %d\n", part2(races))
} }
func part1(races []Race) int { func part1(races []Race) int {
res := 1 res := 1
for _, race := range races { for _, race := range races {
res *= numberOfWaysToWinRace(race)
}
return res
}
func part2(races []Race) int {
bigRace, err := combineRaces(races)
if err != nil {
panic(err)
}
return numberOfWaysToWinRace(bigRace)
}
func numberOfWaysToWinRace(race Race) int {
possibleWins := 0 possibleWins := 0
for timeHeld := 0; timeHeld <= race.time; timeHeld++ { for timeHeld := 0; timeHeld <= race.time; timeHeld++ {
distance := distanceForTimeHeld(timeHeld, race.time) distance := distanceForTimeHeld(timeHeld, race.time)
@ -60,10 +76,7 @@ func part1(races []Race) int {
} }
} }
res *= possibleWins return possibleWins
}
return res
} }
func distanceForTimeHeld(buttonHeld int, raceTime int) int { func distanceForTimeHeld(buttonHeld int, raceTime int) int {
@ -123,6 +136,47 @@ func removeRowPrefix(s string, prefix string) string {
return pattern.ReplaceAllLiteralString(s, "") return pattern.ReplaceAllLiteralString(s, "")
} }
func combineRaces(races []Race) (Race, error) {
if len(races) == 0 {
return Race{}, errors.New("cannot combine zero races into one")
}
raceTimes := make([]int, len(races))
raceRecords := make([]int, len(races))
for i, race := range races {
raceTimes[i] = race.time
raceRecords[i] = race.recordDistance
}
bigRaceTime := smashNumbers(raceTimes)
bigRaceRecord := smashNumbers(raceRecords)
return Race{
time: bigRaceTime,
recordDistance: bigRaceRecord,
}, nil
}
func smashNumbers(nums []int) int {
if len(nums) == 0 {
// programmer error
panic("cannot combine zero numbers into a big one")
}
s := ""
for _, n := range nums {
s += strconv.Itoa(n)
}
bigNum, err := strconv.Atoi(s)
if err != nil {
// should never fail, given we only use numbers as is
panic(fmt.Sprintf("converting %s to a number failed: %w", s, err))
}
return bigNum
}
func tryParse[T any](items []string, doParse func(s string) (T, error)) ([]T, error) { func tryParse[T any](items []string, doParse func(s string) (T, error)) ([]T, error) {
res := []T{} res := []T{}
for i, line := range items { for i, line := range items {