day 17b complete

took a little longer than expected because the regex was picking the '.' up before the numbers and causing it to become a truncated float... this made it 0 and thus the incorrect coordinate value.
This commit is contained in:
Luke Else 2021-12-17 22:59:41 +00:00
parent 8a8a1c0ebf
commit 76231d6a37
2 changed files with 126 additions and 1 deletions

View File

@ -94,7 +94,7 @@ func returnContent(path string) *[]int {
defer file.Close() defer file.Close()
scanner := bufio.NewScanner(file) scanner := bufio.NewScanner(file)
regex, _ := regexp.Compile(`[-+]?[.]?[\d]+`) regex, _ := regexp.Compile(`[-+]?[\d]+`)
strings := []string{} strings := []string{}

125
day17/17b/main.go Normal file
View File

@ -0,0 +1,125 @@
package main
import (
"AdventOfCode2021/shared"
"bufio"
"fmt"
"os"
"regexp"
"strconv"
)
func main() {
content := returnContent("../input")
//content := returnContent("../testInput")
coordLeft := shared.Coordinate{
X: shared.Min((*content)[0], (*content)[1]),
Y: shared.Max((*content)[2], (*content)[3]),
}
coordRight := shared.Coordinate{
X: shared.Max((*content)[0], (*content)[1]),
Y: shared.Min((*content)[2], (*content)[3]),
}
answer := make(map[shared.Coordinate]bool)
y := 0
for {
for x := 1; x <= coordRight.X; x++ {
//Test with positive Y velocity
probe := Probe{
Position: &shared.Coordinate{X: 0, Y: 0},
Velocity: &shared.Coordinate{X: x, Y: y},
}
success, _ := probe.Model(&coordLeft, &coordRight)
if success {
answer[shared.Coordinate{X: x, Y: y}] = true
}
//Test with negative Y velocity
probe = Probe{
Position: &shared.Coordinate{X: 0, Y: 0},
Velocity: &shared.Coordinate{X: x, Y: -y},
}
success, _ = probe.Model(&coordLeft, &coordRight)
if success {
answer[shared.Coordinate{X: x, Y: -y}] = true
}
}
fmt.Println(len(answer))
y++
}
}
type Probe struct {
Position *shared.Coordinate
Velocity *shared.Coordinate
}
func (p *Probe) Step() {
p.Position.X += p.Velocity.X
p.Position.Y += p.Velocity.Y
if p.Velocity.X > 0 {
p.Velocity.X--
} else if p.Velocity.X < 0 {
p.Velocity.X++
}
p.Velocity.Y--
}
func (p *Probe) Model(left *shared.Coordinate, right *shared.Coordinate) (success bool, maxY int) {
maxY = 0
for p.Position.X <= right.X && p.Position.Y >= right.Y {
p.Step()
if p.Position.Y > maxY {
maxY = p.Position.Y
}
if CheckLocation(p, left, right) {
return true, maxY
}
}
return false, maxY
}
func CheckLocation(probe *Probe, left *shared.Coordinate, right *shared.Coordinate) bool {
if probe.Position.X >= left.X && probe.Position.X <= right.X {
if probe.Position.Y <= left.Y && probe.Position.Y >= right.Y {
return true
}
}
return false
}
func returnContent(path string) *[]int {
//read file and return it as an array of integers
file, err := os.Open(path)
var content []int
if err != nil {
fmt.Println("Unlucky, the file didn't open")
return &content
}
defer file.Close()
scanner := bufio.NewScanner(file)
regex, _ := regexp.Compile(`[-+]?[\d]+`)
strings := []string{}
for scanner.Scan() {
strings = regex.FindAllString(scanner.Text(), 4)
}
for _, val := range strings {
num, _ := strconv.Atoi(val)
content = append(content, num)
}
return &content
}