AdventOfCode/2023/Day3/main.go
2023-12-12 13:23:20 +01:00

96 lines
2 KiB
Go

package main
import (
"fmt"
"log"
"os"
"strconv"
"strings"
)
func is_adjacent_to_symbol(y int, x int, lines []string) bool {
for i := y - 1; i <= y+1; i++ {
for j := x - 1; j <= x+1; j++ {
if i < 0 || j < 0 || i >= len(lines) || j >= len(lines[i]) {
continue
}
_, error := strconv.Atoi(string(lines[i][j]))
if error == nil {
continue
}
if lines[i][j] != '.' {
return true
}
}
}
return false
}
func print_number_with_surronding(number string, y int, end_x int, lines []string) {
x := end_x - len(number) + 1
for i := y - 1; i <= y+1; i++ {
for j := x - 1; j <= end_x+1; j++ {
if i < 0 || j < 0 || i >= len(lines) || j >= len(lines[i]) {
continue
}
fmt.Print(string(lines[i][j]))
}
fmt.Println()
}
fmt.Println()
fmt.Println()
}
func add_to_sum(number string, is_valid bool, sum_of_parts int) int {
if is_valid {
number, error := strconv.Atoi(number)
if error != nil {
fmt.Println("Error converting string to int")
}
sum_of_parts += number
}
return sum_of_parts
}
func main() {
content, err := os.ReadFile("input.txt")
if err != nil {
log.Fatal(err)
}
lines := strings.Split(string(content), "\n")
sum_of_parts := 0
for y, line := range lines {
current_number_string := ""
current_number_is_valid := false
for x, char := range line {
_, err := strconv.Atoi(string(char))
if err != nil {
if current_number_string != "" {
sum_of_parts = add_to_sum(current_number_string, current_number_is_valid, sum_of_parts)
current_number_string = ""
}
current_number_is_valid = false
continue
}
current_number_string += string(char)
if !current_number_is_valid && is_adjacent_to_symbol(y, x, lines) {
current_number_is_valid = true
}
if x == len(line) - 1 {
sum_of_parts = add_to_sum(current_number_string, current_number_is_valid, sum_of_parts)
}
}
}
fmt.Println(sum_of_parts)
}