code.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. package main
  2. import (
  3. "bufio"
  4. "fmt"
  5. "log"
  6. "os"
  7. )
  8. func readInput(file *os.File) ([]string, int) {
  9. scanner := bufio.NewScanner(file)
  10. var maze []string
  11. start := -1
  12. for scanner.Scan() {
  13. line := scanner.Text()
  14. if line == "" {
  15. continue
  16. }
  17. if start < 0 {
  18. for i := range line {
  19. if line[i] == 'S' {
  20. start = i
  21. break
  22. }
  23. }
  24. }
  25. maze = append(maze, line)
  26. }
  27. return maze, start
  28. }
  29. func part1(maze []string, beams []int) int {
  30. var count int
  31. for row := 1; row < len(maze); row++ {
  32. for i := range beams {
  33. if beams[i] == 0 {
  34. continue
  35. }
  36. if maze[row][i] == '^' {
  37. if i > 0 {
  38. beams[i-1]++
  39. }
  40. if i < len(beams)-1 {
  41. beams[i+1]++
  42. }
  43. beams[i] = 0
  44. count++
  45. }
  46. }
  47. }
  48. return count
  49. }
  50. func part2(maze []string, x, y int) int {
  51. if y >= len(maze) {
  52. return 1
  53. }
  54. var count int
  55. var left, right int
  56. if maze[y][x] == '.' {
  57. count += part2(maze, x, y+1)
  58. } else if maze[y][x] == '^' {
  59. if x > 0 {
  60. left += part2(maze, x-1, y+1)
  61. }
  62. if x < len(maze[0])-1 {
  63. right += part2(maze, x+1, y+1)
  64. }
  65. count += left + right
  66. }
  67. return count
  68. }
  69. func main() {
  70. if len(os.Args) < 2 {
  71. log.Fatal("You need to specify a file!")
  72. }
  73. filePath := os.Args[1]
  74. file, err := os.Open(filePath)
  75. if err != nil {
  76. log.Fatalf("Failed to open %s!\n", filePath)
  77. }
  78. maze, start := readInput(file)
  79. beams := make([]int, len(maze[0]))
  80. beams[start] = 1
  81. fmt.Println("Part1:", part1(maze, beams))
  82. fmt.Println("Part2:", part2(maze, start, 1))
  83. }