Jelajahi Sumber

day 4,5,6 go)))

metya 1 tahun lalu
induk
melakukan
5347f18e3e

+ 18 - 0
.vscode/launch.json

@@ -0,0 +1,18 @@
+{
+    // Use IntelliSense to learn about possible attributes.
+    // Hover to view descriptions of existing attributes.
+    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
+    "version": "0.2.0",
+    "configurations": [
+        {
+            "name": "Launch Package",
+            "type": "go",
+            "request": "launch",
+            "mode": "auto",
+            "program": "${fileDirname}",
+            "args": [
+                "-example"
+            ]
+        }
+    ]
+}

+ 1 - 1
aoc2024/aocutils.py

@@ -86,7 +86,7 @@ def bench(part):
 
 
 if __name__ == "__main__":
-    day = 3
+    day = 6
     root = os.path.dirname(__file__)
     task_dir = os.path.join(root, f"day{day}")
     generate_readme(task_dir, day)

+ 1 - 1
aoc2024/day1/day1.go

@@ -1,4 +1,4 @@
-package main
+package day1
 
 import (
 	"bufio"

+ 107 - 0
aoc2024/day4/README.md

@@ -0,0 +1,107 @@
+--- Day 4: Ceres Search ---
+---------------------------
+
+"Looks like the Chief's not here. Next!" One of The Historians pulls out a device and pushes the only button on it. After a brief flash, you recognize the interior of the [Ceres monitoring station](/2019/day/10)!
+
+
+As the search for the Chief continues, a small Elf who lives on the station tugs on your shirt; she'd like to know if you could help her with her *word search* (your puzzle input). She only has to find one word: `XMAS`.
+
+
+This word search allows words to be horizontal, vertical, diagonal, written backwards, or even overlapping other words. It's a little unusual, though, as you don't merely need to find one instance of `XMAS` - you need to find *all of them*. Here are a few ways `XMAS` might appear, where irrelevant characters have been replaced with `.`:
+
+```
+..X...
+.SAMX.
+.A..A.
+XMAS.S
+.X....
+
+```
+
+The actual word search will be full of letters instead. For example:
+
+
+
+```
+MMMSXXMASM
+MSAMXMSMSA
+AMXSXMAAMM
+MSAMASMSMX
+XMASAMXAMM
+XXAMMXXAMA
+SMSMSASXSS
+SAXAMASAAA
+MAMMMXMMMM
+MXMXAXMASX
+
+```
+
+In this word search, `XMAS` occurs a total of `*18*` times; here's the same word search again, but where letters not involved in any `XMAS` have been replaced with `.`:
+
+
+
+```
+....XXMAS.
+.SAMXMS...
+...S..A...
+..A.A.MS.X
+XMASAMX.MM
+X.....XA.A
+S.S.S.S.SS
+.A.A.A.A.A
+..M.M.M.MM
+.X.X.XMASX
+
+```
+
+Take a look at the little Elf's word search. *How many times does `XMAS` appear?*
+
+
+
+
+
+
+--- Part Two ---
+----------------
+
+The Elf looks quizzically at you. Did you misunderstand the assignment?
+
+
+Looking for the instructions, you flip over the word search to find that this isn't actually an `*XMAS*` puzzle; it's an `*X-MAS*` puzzle in which you're supposed to find two `MAS` in the shape of an `X`. One way to achieve that is like this:
+
+
+
+```
+M.S
+.A.
+M.S
+
+```
+
+Irrelevant characters have again been replaced with `.` in the above diagram. Within the `X`, each `MAS` can be written forwards or backwards.
+
+
+Here's the same example from before, but this time all of the `X-MAS`es have been kept instead:
+
+
+
+```
+.M.S......
+..A..MSMS.
+.M.S.MAA..
+..A.ASMSM.
+.M.S.M....
+..........
+S.S.S.S.S.
+.A.A.A.A..
+M.M.M.M.M.
+..........
+
+```
+
+In this example, an `X-MAS` appears `*9*` times.
+
+
+Flip the word search from the instructions back over to the word search side and try again. *How many times does an `X-MAS` appear?*
+
+

+ 115 - 0
aoc2024/day4/day4.go

@@ -0,0 +1,115 @@
+package main
+
+import (
+	"bufio"
+	"flag"
+	"fmt"
+	"os"
+	"slices"
+)
+
+func main() {
+	args := flag.Bool("example", false, "example or input")
+	flag.Parse()
+	filename := "input.txt"
+	if *args {
+		filename = "example.txt"
+	}
+	file, err := os.Open(filename)
+	if err != nil {
+		fmt.Println(err)
+		return
+	}
+	defer file.Close()
+
+	var grid []string
+	reader := bufio.NewReader(file)
+	for {
+		line, _, _ := reader.ReadLine()
+		if len(line) == 0 {
+			break
+		}
+		grid = append(grid, string(line))
+	}
+
+	rows := len(grid)
+	cols := len(grid[0])
+
+	xmas := "XMAS"
+	mas := "MAS"
+
+	directions := [][2]int{
+		{0, 1},   // →
+		{0, -1},  // ←
+		{-1, 0},  // ↓
+		{1, 0},   // ↑
+		{1, 1},   // ↘
+		{-1, -1}, // ↖
+		{-1, 1},  // ↗
+		{1, -1},  // ↙
+	}
+
+	uniqueWords := make(map[[3]int]bool) // [row, col, directionIndex]
+
+	isXMAS := func(startRow, startCol, dirX, dirY int) bool {
+		for i := 0; i < len(xmas); i++ {
+			newRow := startRow + i*dirX
+			newCol := startCol + i*dirY
+			if newRow < 0 || newRow >= rows || newCol < 0 || newCol >= cols || grid[newRow][newCol] != xmas[i] {
+				return false
+			}
+		}
+		return true
+	}
+
+	isMAS := func(diagonal []byte) bool {
+		line := string(diagonal)
+		slices.Reverse(diagonal)
+		return line == mas || string(diagonal) == mas
+	}
+
+	totalCount := 0
+	totalXmas := 0
+	// part1
+	for row := 0; row < rows; row++ {
+		for col := 0; col < cols; col++ {
+			if grid[row][col] == 'X' {
+				for dirIndex, dir := range directions {
+					dirX, dirY := dir[0], dir[1]
+					if isXMAS(row, col, dirX, dirY) {
+						key := [3]int{row, col, dirIndex}
+						if !uniqueWords[key] {
+							uniqueWords[key] = true
+							totalCount++
+						}
+					}
+				}
+			}
+		}
+	}
+	//part2
+	for row := 1; row < rows-1; row++ {
+		for col := 1; col < cols-1; col++ {
+			if grid[row][col] == 'A' {
+				// ↘
+				diagonal1 := []byte{
+					grid[row-1][col-1],
+					grid[row][col],
+					grid[row+1][col+1],
+				}
+				// ↖
+				diagonal2 := []byte{
+					grid[row+1][col-1],
+					grid[row][col],
+					grid[row-1][col+1],
+				}
+
+				if isMAS(diagonal1) && isMAS(diagonal2) {
+					totalXmas++
+				}
+			}
+		}
+	}
+	fmt.Println("Total count of XMAS:", totalCount)
+	fmt.Println("Total count of X-MAS:", totalXmas)
+}

+ 0 - 0
aoc2024/day4/day4.py


+ 9 - 0
aoc2024/day4/day4_test.go

@@ -0,0 +1,9 @@
+package main
+
+import "testing"
+
+func BenchmarkF(b *testing.B) {
+	for i := 0; i < b.N; i++ {
+		main()
+	}
+}

+ 10 - 0
aoc2024/day4/example.txt

@@ -0,0 +1,10 @@
+MMMSXXMASM
+MSAMXMSMSA
+AMXSXMAAMM
+MSAMASMSMX
+XMASAMXAMM
+XXAMMXXAMA
+SMSMSASXSS
+SAXAMASAAA
+MAMMMXMMMM
+MXMXAXMASX

+ 140 - 0
aoc2024/day4/input.txt

@@ -0,0 +1,140 @@
+XASXMAXXMSXXSMMSXMMSMXSMXMSSMSSSMMSMAMXMXSMMMMAXAMXSASXSSMMSSMXAMXMSAMXMMXAXXXSAMXXXXXMMXSXMXXSMASAMXMXAXXMASAMXXXMAMMMSXSXMXMMMSAASXSMSSMMS
+XASAMSSMAMMMAMAAAMASMAMAAXMASAAASAAMAMAMAAAAASMSSSSMAXAAAXASASMMMMMMXMASXMAMXXXXSMSMSXSAAXAMXMASMXMMSMSAXSXMMSXSMMAAMXAMAAMMAAAAXMXSAAAAXAAM
+MXSXMAAMXAAAXMMSSMAXMASXSSSSMMSMMSXSASMSMSSMMMAAAXXXXMMMMMXXAMMAAAASMMAAAXMASMXXXAAASAMMXSASASMMMAMXSASASASMAXXMAMSSSMSSMMAXSMMSXMMMMMMMXAMX
+SAMMMSSMMXXSXXXAAMSMSASXAAXMXXAAXXXMAXAAAXXMASMMMMMMXMXXXXSMXMSSMSASASMMXMMXMAAMASMSMSMAASXSAAAASAXAMAMXAAXMASMSSMXAMMMAMXSAMAMAASXMMSSMSAMX
+MASAAAAMSMMMMMMSMMMAMAXMMMMMXMSSMMXMSMMMMMAMXASAXAASXMMASAAXAXAXMXMXMXAASXMAMSXSAMMXMMMMMSAMXMSMSMSMMAMSMXMMASAMXAMMSASAMMXASAMSXMAMXAAXSAMA
+SSMXMSMAAMAAXXAMXASMMSMAMXSXSAMXXMAAAAXSXSAMXMASMSXMASXAMSAMXMMMSASMXMXMMAMSMXAMASXMXAASXMMMMXMMXAAXXAMXXAAMAMAMXXXASXSASXMMSAMMASXMMMMMMMMS
+XXXXMAMMMSSSMXSXSASXAXSXMASAMXSMXMASMSMSXMASXXMMXMXSAMMXMAXAMAXXSXSAASMASXMXAMXMMMAASMXXAMXMMAXMXMSMSAMSSMSMMSSSSMMMSXMXMASXSMMXAXAXSSSMXAAX
+MMXSSXSMXAMAMAAAMSXMXMMXMASXMMSAMXXAAMXSASAMMXXSXMXMASXSSSMXSSMXXMXMMSAXMASMMMSMASAMXMASXSAMSSMSMAAAMAMAXAMAMAMXAXAXSAMXMXAXMMSMMSXMAAAMSAMX
+AXMXMASMMASAMXSXMMXSAMAAMXMMMAXMMSMMXMASAMXSXMXMAAMAMSAMAAAMSAMMSXMXSXMXAXMASAMXAXMASXMAMMAMAAASMMMSSSMSSMXSAMXSMSMXXAMXSSMASAMAMMASMMMASMMM
+XMAMSXSASASASMXXMAMMAASXSAAAMMXAAXXAMMMMSMSMXMAXMXMAMXAMSMMMSAMASAMXSAMMMMXMMAMMSXXAMAXXAMSMMSMMAXXXMAAAAMAMAXXAMXXSMSAXAAXAMMMAMSXMAXXMSASX
+MSSMXASAMXSMMMAXASMSMMAXMAMSASXMAXMMSAXSASAAASMXMASMSSMMMAAXSAMMSAMAMAMMSAMSSSMSAMMSSSMSMXMAXXASXMMMMMMMSMASASXSXMASAXXMSSMMXMXMMMMSAMMXSAMX
+MAMMMMMMMMMASAMMMXAAXXMASAAXASMMSXMAXMXSMSMSMSXAMMXXAMXASXMXXAMASAMSSXAAMAMAAMXMASAAAAAAXSSSMMAMASASXXXXMMXSASAXXAAMAMAXXMXSASASAMASAMXAMAMX
+MASXAXAMXXSAMMAAXMSMMXMAMXXMMMAAMMMSXMMSXMXAAXXMSAMMSSMMSMMMMAMASAMAXMASXMMMSXAXXMMMSMMMAXAAXXSSMSASMMSAMXXMAMAMXSSMSMSMAMAXXSXSASXMSSMXSAMM
+SXMXMSSSMMMASMSMSMAAMASXMMXSASMMXXAMXXASASMMXMAMAAXAMAMAXAASXMMXMMSMXXAXMSXMAXXSSSXAXAAXMMMMMMXAXMMMXAAMAMMMXMAMAMXAMAXAAMASAMASAMXMAMMXSASA
+MMMXMXXAXAMAMMAAAMSMMAXAASASAXXXSMSSSMAMXMAMXXASXSMMSMMXSMMXAXSXMAXAMMMXXMAMSAMXAAMSSSMMXAAAAXSAMXXAASMXAASMASXMSSMAMAMMXSAAAMAMAMSMAXSAXAMM
+SASASMXMMSXSXSMSMMXSMXXXMMASAXSXMAXAAMMMSSMMMXASXMXMAAXMXMMMXMSAMXSXSASMASAMMSSMMMMAAAXMSSSSMXXAMXMAXXXMSMSAAMAMAMAMMMMXXMMSSMMXAMXXAXMASXSM
+MASMMAMSAMMMMAMMXSAMXSMSAMXMMMAAMAMXMAMAMAAAAMSMXSASMXMAAAXSAMXAMAAMSAMSAMXSAMMASAMXSSMMMAMMXXMSMMXMSSMMXAMMXSAMMSAAAAMXAAMAXASXSMSMMSMAMAAX
+MMMMMSMMAMXAAMMAAMMXAMMAAAXAXSSXMAMXMAMASMMMXMAAXSASAMSSMSASASXMMMSXMAMXXMMMMXMAMAXAMXAXXSAAASAAAXXXAAMAMAMAAXAMXSASMXSASXMSSMMAMASAMSMMMSXM
+SAAMAMAMAMSSSXMMXSSMSSSSSMSSXAAMSXSXSASASAMAMSMSMMMMXAAXAXMSAMASXSMMXSMSMSXSSSMMXMMXSSSMAXMXSXMMAMXMSXMASMMMXSAMAXAXMASMMMMASAMXMAMAMXAXAMXA
+SSSMASXMMXMAMXMMAMXAAAAMMAAXAASMSXAAXAMASMMAXAMAAMSAMMMMSMMMXSAMXMAAMXAMAAXMAAXAAMMXMAMMAMMXXAXMAXSAAXSXSXXAASAMAMSMMMXXMXMMSMMSMXSXMSXMXMMS
+XAMMAMAMXMMSMMSMAXMMMSMMSMMXMAMAXXMSMSMMMXXMMSSSSMMXMAAAMAXXMMMSXMMMSMAMSMMMSMMSXXASMAMMASMMMAMSSMASMXSAXXMMMXXXMXMXXAMMSASMMMAXMXMXAMXSAMXA
+MMXMXSAMMXAXAXMSMSXXAAAAAMSMMXMAMXXAAMASMSXSAAXXAAMAMSSSSSMSXAAXMSMXAMXMAMAMXAMASXXMMMSMMMAMMSMMAMMAXAMAMSXSSMSSMMMASAXASMXAAMXSXAMXMAMXASMS
+AXMSMSXXAMXSMMMMXAMMMSMMMSAASAMMMSSMSSXMAAAMXSMXSSMAMMAMMAASXMMSAAXSXSSSSSSMMAMASXAXXASXSSMXAMAXAMXAMMMSMMASXAAXAASAMXMMXXSSMMSMMXSAMSMSMMMA
+SMAAAMASXMMSMMXMMMMXAAXASMMMMASXAAAXAXAMSMMMAAAXXAMXXMAMSMMMAXSMMMMMSAAAAAXAXSMMSMMMSAMAXXXMSSMSSSMMSAAXAMSMMMMXSMSASXXSXMMXAXMAAXXASMAAXASM
+XMSMSMAMAAAMMSASAAAMSSSXSAMXSAMMMSSMMSMMAMAXSXSXSAMAXSAMXMMSSMXAAXASMMMMMSMMXMAXMASASAMSMMSAMXXMXAAASMSSMMASAAXAXASAMAMMASMXSMSMMSSMMMSMSMSX
+MXXMAXASMMSSXMASMMMAMXMAMXMAMAMXAAXMMAAXMSAXMSMASMMSASAXSMAAXAMXMSXXSMXSAAMMAMAMXMMXSAMXMAXMASMSMMMMSMXAMAMXSMSXMAMXMXASMMSAAAMXAXXASAMXAASA
+MMSXMMMXMAAXMMXMMMSSMMMAMSMSMSMMSSSSSSMMXSXSMAMAMXAXASMMSMMSSSMSMAXMXSAMXSASASXSSXMASMMSXMMSMMAMXSAXXMXMAXXMAXSAMAMMAMXXSAMXMMMMMSSMMAXSMMMS
+MASMSASXMMMSSMAAAAMAAXSSMSAAAAXXAAMAAAMSXMASMXMASMMMMMAAMAMMXXMASMAMAMMSMXAMAMAAXXSASAXMASMASMMMASXXAXMSMSSSMAXMXSMSAXMAMXMSMSXXMAMASXMASAAX
+MXXAXAXMXAAMASXXMSSSMMMMAXSMSMSAMXMMMMMSAMAMAMAMXXAASAMXXAMMSSSMSXAMAMXAAMXMSMMMMXMAMXMSXASAMXSMAMMSSMXAAMAAXAXSAMXSASMSMAXAAMSAXASMMASAMMSM
+MAMSMSMSXMXSAMXASMMMAMAMMMMXXXAMXAMAMAXSAMASAMSSSSSSSMAMSMSAAAAAMXMSASXMSMSAXXXXMAMXXSMXSXMMSMSMSXMAMASMSMSMMSAMXSXMAMAMSSXMXMXXMAXXXAMASAXM
+MASAAMAAXSAMXSSXMASMMMAMXAMAXMMMSMXAMSXSAMAXAMXAAAXMXMAXAMXMMMMMMSXXMAXMMMSASXSMSMMMMSAMAXMAAAXAAMMMXMXXAMXMAXXMASAMMMXMAXXMSSMMASXMMSSXMASX
+MXSMMMMMXMASAXAMSAMAASMMSASXSAXAAAMSXMASMMSMSSMMMMMMXSSSXSMMSSMXXSAMXMSMAAMAMAXAAMSSMXAMMSASMSMSMAASMSMMSSSMMSAMXXAMXSSMAMXSASAMXXAXAAMAMAXA
+XMXMAXXAXSAMMXSAMAMXMMAAXAAASMMSXSXXAMAMXXMAAAMSAMASMAXAMMMXAAMSAXSAMXSMMSSSMMMSMAAAMSMMXMAXAXAXMSMMAAAXMAXAXSXXAMSMMAAMMMXXAXMMAMSMMMSAMASM
+MAASXXMMXMAXSXMXMASMMMMMMXMAMMAXXMAMSMXMAAMMMSXMASAXMMMMMAAMSSMSAXXXMXMAXAAMXAAMXMMSMAAASMMMSMAMAXAMSSSMMMMSMMMSMMXAMSXMASMMSMAMXSXXXXSXXAXX
+AMXMSXAMMMSMXMSMSASAXAXXMMMMSMMSSMAMMMMSMSXAAMMSMMXSAAASXXXXAAXMMMSMMASAMMSMMMMXAMAMXMXMMAAAMMXMAMXMXAMXMXMAAAAXXASXMAMSXSAAAMAMXAXXSAMXMXSM
+XXAAMSSMAAMXAAAAMXSMMSAMXAAXAAASASXMAAMAAAXMMSAXAAAXXMSSMAXMSSMSAMXASMSMSMMMSMMMSMAXAXSASXMSSXSMMSXSXMSAMSSSSMMXMXSAXXAMAMMSSSMMSMSMSXSASAAX
+MSMSMAMXMSSSXSMSSMMXMMXMSSSSMSMSAMXSSXSMSMMXAMXSMMSXXXAXMSMMXMASMSSXMAXMAMAAAAMAXMMMAXMAMAAAMXMAXXMMAXSASMMMXMXSAAXMMMSMAMXAXAMMAAAASAAASXSM
+XAAXMMSXMAXXAXMAMAMMMXMXAXMXAMXMAMXAMXSXXXSAMXMXMAMMAMMMXAMMAMAMXXXASXMSMSMXSXMXSAXMSMMASMMMSMSSMMMSXMSSMASMMAAMMSMMSAAMSSMASMMSMSMSMSMAMAXX
+MMMMAAMMXSMMSMMASAMAAASMMSSMXMMMAMXAXXSASAMXMASASASAAMAAXMMSASMXSAMMMAAXMAMXMXSXMAMSAMSAXAXMAXAMSAMMAMXXSAMAMMXSAXXAMXXSAMAAMXAXAMMXXXXAMMMS
+MASMMMMXAXMAMASASXSMSXSAMAMXMMMSSMSMMXMAMMMSSMSAMXSXMMXSSXASXSMMMMSSSMMXXAMASAMXMAMMAXMXSSMMSMMSMSXMAMMMMXSXMAMMMXMSXSXMMSSMMXSSXMASMSMMMXAX
+MAXAMXSMAXMAMMAMXASAMXSXMAMSXSAAAMAAXAMXMXAAAMMXMMMAMSAMXMMMAXAXSAMMAXAMSSXSAMXASXSMXMXAXAAAAAXXAAMASXMAMXSXMASAMSAXASXAXAXAXXMXMMXMASASMMMS
+MSSMMAMMMMSSSMASMMMAMXXASMMSAMMXSASMMMSSSMMSSMAXMASAMMXMXMMSMSMMMASXSMXXAMXXAMXXSASAASMSSSMMSMMMMMSAMASASMXASXXAXSAMAMSSMMSXMSSSMMAMSMAMAAXX
+XAAXMASASMMAAXSMMSMSMMSMMSAMXMAMAAAAAASMXMMMAMASMMMMSAMXMAAAXAAXSAMAXAXMMMAMAMMSMAMSMMAXAXXMAMMAMXMASXSAAASAMMMSMMAMMMMXXXMASAAAXMASMMASXMMM
+ASMMSXSXMAMSMMMAMXSAAMASMMMSXXAMMMMSMMSAASASXMASMASAXMASMMSXSXSMMXMSMSMMXMMSMMMXMAMXXMSMXMASMMXSMMSAMMMMMMMAMAXXASXMSAMXMMMXMMSMMMXXAXAXAMXM
+MXXAXXMASMMXSASAMXSSXSASXAXMASXSXMMXXSMMMSASAMAMXAMXSSXXAAXASAMXSAMAXAASMXXAMAMASMSMSXXAMAMAAMAXAMSAMXAMXMSSMMSSMMMMSASMSASXSAMAMSMMSMSSMMAM
+MSSMMXSASAASMMSSMAMAXMAXMMSXXMXAAMAAMXXAXMAMXMSSMXSAMXMSMMMAMAMXSASMSSSMAMSASASMXMAASAMSASXSAMAMAMMASMASMXAXAAXASAAXSAMXMMAMMXXAMASAXAMXXSAS
+XAAAAAMXSMMSSXXMMXSXMASMSXMASMMSSMMSSMSSSSXSAXXMXAMXXAMASAMXMAMMSAMXMMAMSXXASAMXSMMMMAMXSMAXAMMSMMSAMMXMAMXSMSSMMSAMMMSXSAASXMSSMMMXSAMAASAS
+MSSMMSSMXXAMAXMXXAXAMXXAXASMAAXAMMXAAAMAXAASMMSMXMMSSMSASMMMSMSAMMSXMSAMXMMXMXMXAAXAMXMXXXAMASAAAMMASXMMSAMXXAAAXMXSXAXMASXSXAMAAXXAXAMXMMAM
+AXAXMXAXSMSSMSMMMMSMMMXXSAMSMMMSSSSSMMMMMMMMXAAXXAAAAAMXMAMAAMMXMAMAXXMXAMAXMASXSMMSSMMXSMSSXMXSMMMAMAAAMXXXASXMMMAMMSMMAMMMASMAMMMMSSMMXSAS
+SMSMSXMMMAMXXSAMAAAXAMSAMXAXXMAMXMAAMXAXXSAMMSSMSMMSMMMXSAMMXSAMXAXMMSMSAMXAXXMAMAAMAAAXXAXMASAMMSMMSMMSSSMMMMSAAMAMAMAMASASAMXXMAXAAAAAXSAM
+XAXASASAMSMMMSAMSSXSAMASXMAXXMAXSMSMMSMSXSASAMAMXXXAXAXXMAXMAMASXMSAAAXMMMXSMXMAMMMSSSMXMSMMMMXSAAAXXXXAAAXSAAMMSMMXXXAMAXAMXXMXSXXMSXMMXMAM
+MAMAMSMXSAAAASAMAMAMMSMXXXMASMXSAAAXXMASXXXMMSXMSMMXSSSSSSSMMSXMAAAMMMSSSSMAAASASAXXAAXAXXMASMMMXSSMMMMMSMMSMXSXMMSAXXSMXMXXXAXAASXXAMMMASXM
+MXMAMASXSXXMXSAMAMXMXAMMASMMSASAMSMSSSMXASXSAMXMASAMXAAAAAAMAMXSMMMSXXAAAASMSMSSSXSMMXSXMAXASXAXXMAMAXAXAAXXMASAMAMMSAXAMSAMMAMSAMXMMASMXMMM
+MSSXSASXMAXSXSXMAMXXXAXSASAAMMMMMAXSAAMAMAAMAMXXAMMAMMMMMMMMAXXSAMAMXSXMSAMXXMXMMMXAMAMAMSMMSMSMAMSXMXSXXAMXXAMAMXAAMXMAAMASAXMMMSXASAMXAAAX
+MXXXMAMAMAXSAMXSXXMXSSMMASMMXAMXSXMMSMMAXMSXMMSMSXSSXXAAXSASXSASXMXSAMXXMASMSMAXAAXMMAXAAAAXXAASMMAASAMASMXMMXSAMSMXSXMAMSAMMSSXMAXMMMSSSMMA
+XMXMASMMMXMMAMXXAASXXXAMAMAMSMSMMAAMMXXXMXXAMXAAAASAMSMSSMAMAAMMXMMMXSMXSAMAXMASXSSSSSSMXSSMMSMAMMXAMAMMASAXXMXMAMXASASAXMASAXAMAMMXAMXAAASX
+SAXASXAXMAASXMMMXMMAAXXMMXXMAXAAMXSMMSSSMASMMSMSMMMAMAMMMMAMAMXMAMSSXAAAMMMSMMAMAAAAAAAAAXAMAAMMXSAMSMMSAMMMSAMXSAMXMAMMXMMMXMXXAMXXMMSMSMMA
+XXAXAMXMSSXMASAMASXMMMSAMSSMSSSXSAMAMXASMAMMASAXMASXMASMASASAXXSAAAMSMXMXSXMXMSSMMMMMMMMMXAASXSAAMAMXMAMAMAAMAMAMAAMMSMMASAAMSASXXSAXAXXAAXS
+MMSSSMSXAXAMASASMMAMMXMAMAAAAAMXMXSAMMMMMSSMAMMMMXAXSAXMAMXSXMXAMMXXXMAXXAASXXXAMXMASXMASMMMMASAMSSMMMAXSAMXSMMSXSMSAXAMAAMMSAASAASXMAXXXMXM
+SXAAAAAMSSMMAXMMMSAMMXSMMSSMMMMXSXSXMAXMXMAMMSMXMAMXMAMMMMXSAMXXXMXMASXSMMMMMSSMMXMASASMMASMMAMAMAMAAXASAXXXMASMAMSMASXMXSXXXMMMMMMXMASMAMAS
+AMMSMXMAMAXMXMSAMMXMMAMMMMAMXXSMMASMSSSMASXMAMXAXSXMSXSAXSAMAMASMMMXAMXMXAMAAAAXAAMMSXMXSMMMMSXXMAMSMSSMMMSMSXMMAMAMMXMXAMXMMXXSXAXMAAAMAMAS
+MXXXMAXMMAMXSXMASMSMMASAXSAMXAMAMAMMAAAXAMMMASMMXXAMAASAMMASAMAXAAAMSSMMXSSMMSMMSASASXMXSAMAAMXSMMXAMXAAXAXAXMAMSSMMMAMMSSMAAXXMAMXSMXXMXMXS
+XXSASXSSMSSXMXSAMXAASASXXAMXXMSSMMSMMMMMMXASAMMMAMMMMXMMMSAMAMSSMMMSAAAASMXXMAXAAMMMMAMAXAXMMSXMASXMSSSMMXMAMAXMAMAAMXSAMAASMMSMXAAXMAXMAAAX
+MMSASAAAAAXMSAMASXXMMAXMXMSASXAXAAMASXXMASMMMSSMMSSMMSAAAMASXMAAMMSMMXMMSXAXSSMMMXAAMMMAXSMSASAMAMAAXMAMSAMXSMXMAXMMSAMXSXMAAASXAMASXAAAXMMS
+MAMXMMSMMMSAMXSAMAMSSSXSAAAMAMXSAMXASXXMASAAAAMAAAAAAXXMXSAMMSXMMXAAXSAMXMAMMXMAXMSSSSMMMMAMASAMASMMMXSASXSAXMASMXSAMASXMMMMMMMAMSAAMMSXSAXX
+MXSXSXAXAMAXXXMAXAAXAAAAMSMMMSXMAAMXSXXMASXMMSSMMSMMMSMMMMASASAXXSXSMAMSSMMXSAMMXMAAMMASAMXMMMXMMXXMASMMMXMMMSMSAXXAMSXMAAXAXXSMMMXSXAAAMAMX
+AMAXMXMSSSMSMMMSXSSMMMMMXAASXMASMMSXMMMSAMAAXXXXXMAXMAMAAXMMASAMXMMXMXMAXMAMXASAXXMXMMASMSMSMMXSMSSSSXXAMMXSAMMMXMSAMXASMMSXMXSXSXMAAMMSMMXX
+MMMXSAXMAAAAAAMMAMXMXXSXSSSMASMMMAMAAAMMMSXMAMMAMSMMSSSSSSMMAMMMAAAAMAMXSMMSSMMMSSXAXMAXXMAAXXAASAAXMAXAMSAMXSXMXAMXMSAMXASXSMMMMXXMXXAMASMA
+XAAAXMMMMMSMSSSMSMASMASXXXAXAMXAMAXMXMMAMAAMXAAMXSAAAXMXMAMMAXAXXMMAMSXXSAAXAXAMXMASXSMMMMSMSMXSMMSMMMMMAMXSAMAMMMSAMXSMMXXMAAAAMXSXMAXSSMAX
+SMMSMXAAXMAXXXXAMXAMMAMXASXMSMSSSSSXSXSMSSXMASXSXSMMSXSMSAMSMMSAMXXSAMXASAMXMSXSAMXMAXAASXMAXXMMXSAMXASAAXASASASAAMASAMXMMMAXSMSAAMASMXMXASX
+XAXMASXSMAMMSMMXMMSMMASXMMSMMAAAAAMAXMMMAXXMXXASAMXXMAMAMSMXMAXXMAMXASAMXAXXXAMMAMAMXMSASAMMMSSSSSXMMASMSMMMMAAMMSMASXSAAAAMXAMXMXXMAMAMXSMX
+MAMMMMAAMXAXAAXAXAMASMAXMASMMMMSMMMMSASMMSSMAMSMSMAXMAMXAMMAMAMXXSAMXMXMXMMAMMMSAMXXXMMMSMMMXMAMAMMSMXMAMAXAAMXXXXMAMAMXSXSXMMMMMSMSASAXSAMX
+MMSXMMSMMSASMSSSMASXMAAXMASMAMXXAXAAMXMAXAAXXMMAMSMSSXMMSXSAMASMMMXMXMASXXSMMSASASMSMXAAXXASXMAMAXAAMAMXXMSSXXAASMMAAAXXXAMMAMXAXAAMAMAXSASM
+XMAAXAMAMXMSXAAXMXMAAMMSMSMMAMSSMMMSSMSXMXSMXMMMMAXAMXXAAAXMSASAAAAMAMXSMAMMAMASAMXAMSAMASXSASXSMSSMASXMXMAXAMXMMXSXSASAMAMXXASMSMSMSMSMSAMA
+XAMMMAXAMAAMMMMMSXSMMMAXXAMMSMMAAMAMAXMAMAXAMXAAMXMSSMMMXSXXMMSMSMMXASAMMMMMASMMMMSSXXAXXMASAMMXMAXXXMASXMAXXSAMSAMXMASMSAMASXXMAAAXMXXAMXMX
+MMSSXMSMMSMMASXMXASMSMXSMXXAXMXSMMAXSMSAMMXXAMXXSSMAAXMAAXMSMASAMASMMMASXMAXMXAXXXAXMXMXXXXMASAAMSSSMSXMMMMXASAXXAXXMXMXSXSMMMASMSMXSAMXMMAM
+XAAMAXAMAAASASAXMXMASAXAAMMSSMAMASXMXAMASAAXSSXXAMMSMMMMXSAMMASASASASXMMASMSSSMMMMXMXXMASXMSXAAXMXAAASMAMASMAMMMMAMXSXMXMASAASAMXAAAAASAMXAM
+MMMSXMAMSMMMASAMSMMXMXMMSMAAAMASAMXASMMAMMSMMAMMAMAMAAXAAMAMXAXXMASMMAAMMMAAAAXAXMASMMMAMXAAXMASXMMMMMAXMAMMMMSMASXMAXMASXMMMMASMMXMSAAXXMMS
+XMXMAMXMXXMMXMAMAASAMXSXMMSSSMAMAXMMMSMXMMAAMAMSAMASAMXMSXMMMSMMMAMMSSMMSMMMMMXSASMMAAMMSMMMSXXMXMXMMMSXMAXSAAAAMXAXMMXASASXXSAMXMMXXXMSMSMS
+MXAMSMAXMAMXSSXMSSMAMAAAMAAMXMSSMMSMAXSXXXSMMSXSXSXAXMAXXAASAMAAMMAAXXMAMMXMAXXMAXXSSMSMAAMSXMAMMXMSAAAXSAAMMMXXXXMMXSMMMAAAMMXMAXMAXMXAAAAX
+SSMSMMSASAMXMAMMXMMSSMMSMSMMSXMAMAMMMMMMSMAAXXAMXMAXAASASXMMSSSMSSMXSMMASXSMMMSMAMMXMASMMSSMAMAMAAASMSSMMMSXSASMSMXMASAMMSMMMSMXMAMXXAXMSMSM
+XASAMXMAAASXMSSSSMMXAAXAAXXMXASAMXMAAAMAAMSMMMAMMMMSSSMAAXMXXMAAAMMMMXMSAMXAAAAMMXMAMMMAMMMMSMAMSSXXMAAMXAAAMAMAAXXSASAMAAAXSAAASXSAASXMMXAA
+SMMMSAMMMMAAXMAXAASXSMMMMMAMMAMXSXSSSSSSSXXXASAMAXXAXXMXMSMSSMMMMXASAAXAAASXMSMMXAMMSXMAMMAAMXAMXXMAMSMMMSSXMAMMMMXMMMAMSMSXSMXMSASAMMAASMSS
+AXAASASAAMSMMMMSSMMAXAAXASAMXSMASAMXAMAAMASMMSASXSMMXSAAXAMAMXSASAMXASMSAMXXXXXSSMMMAMSMSMMMSMSMSASXMXAMAMXAMMSAAAMSXSAMMXXAMXSAMMMASXMMMAAM
+MMMMXXMXXMASAXXAMAMSMSASMXSMMXAXMASMMMMMMAMXMXXMMXASASMSXSMSXMMASAXXXMAMXSMXSAXMASAMAXAMMMMSXAAAXAMMAMAMSSSXMAXXMXAAXMASXMMAMSAXMASAMXASMMMX
+XMSMSSSMMSASMSMMSSMAAMMMXMAXAMMMSSXMXAMXASXMMSXMXSXMASAMAXAMXSMMMMMSSSMSAMXMMMMSAMXMMXMXAAMXMMMSMMAXMSSMXAXMXMSAMMMSAAAMAXMAMXMXSXXAMXMXAXAS
+XSAAXAAAAMMMMXAXAASMSMSAASXMMMAMXMASXXSAAMAAASAMAMXMXMASXMAMAXAAAXXAAAAMMMAMAMXMASAMSASXSSSMAMMXAMAXMAAXMMMSAMAMXXMAMMAMAMSMMXXMMMSMMMMSSMAM
+MSMSMSMMMSSMSMSMSXMXXAMSMSXAASMSMSAMXAMXXMXMAXAMSSSMXMXMASAMXSXMSSMMXMMMMMMMAMASXMAXAAMAMAMMAMXMAMAXMMSMASAMASMSAMSAMSXMXXAXMSSMAAAMMXAAXMAM
+AMAMAXXXAAAMAAAAXXMSMMMMMSMSMSAAXMASMSMAMSMMXSAMXMAMMSMMMMMSMMMAMMMSAAAXSASXXMAMMXSXMSMAMAMMXSSXSMSXXXMMMMASAMXMAMSAMAASXSXMAAAMXSSSXMMSXSSS
+MMAMXMMMMMSMMMMMMMMXAMXAASMMAMMMMMSMXMAMMAXAMXXMASAMMASAMMAMAAAXXSAMMMMXMASAMMSMMAXAMMMXSXSMSMMAMAMXMASAMSXMXSAMAMSAMSMXAMAMMSSMMMMAXMAMASMM
+XSMSSSMMSAMXXXSSMMSSSMSMMSAMSMXSAMXMXMAMSSMMMAMSAXAMSASMXSASMMSMXMXXASMMSAMAMAXAMASXMAMXMMAXMAMAMAMXAMMXMXAAMSASAMSXMMAMSSMMAAMMAAXMAMMSXMAS
+AXAMXXAAMAMSSXMAAAAXAAAXAMAMMMMMAMAMMMMMXXAAMAMMXXAMMAMMASAXXMAMXSSSMSAAMXMXMAXAMXSAMASAMSMMMAMXSXMMSSMASXMMMSAMMXMAMMAMAAXMMSSSSSSXSAASASAM
+MMMMMSMMXAMXXASXMMXMMMMMXSMMMAASASASMSASASMMSASXSAMSMSMMXSAMSSMSAMXAMSMMSMMSMSSMSAMXSMSXMAMASASXAAAAAAMMMMSAMMAMXAXMASASMMMMSXAAAXAAMMXXAMMS
+MAAAAAMMMSSMSXMXXXSMSAXXAAAASMMSASAMASASXAXASASAMSMAAAAXAMAMXAAMMSSSMSAAXAXSAXAAAMMMMAMMSXSAAMAMMMMMMSAMSASASXMAMMMSXSASMMMXAXMMSSMXMSSMAXMX
+SSMSSSXSAAAAXMSAMXAXAASMMSSMSMMMMMMMMMAMMMSXSAMXMAMMMMXMMSAMXMMMAMAAASMMSSMMAMMMMXAMSMSASAMXXSAMXAMMMMASMASXMASMXSASMMAMAASMMXSAAAXSXAXMMMMM
+MMAAXAAMMSMMMXSXAXMASMMMXAXXXXMAMAAMMMMMAXMAMMMXSSMSASAAMMASXMXMMSMMMMMAMAXMAXSSXMXXAAMXMXXSMMAMSASAAMSMMMMMMMMAAMAMXMSMSMSAXAMMXMMMMXXAMAAA
+AMXMSMMMXAXAXAXXXAXAMAAXMASXMMSMSSSMXAMMSAMSMMMAMAASASMSMMMMAAXSMMXXAXMASMSSSSXXAMAMMSMSAMXMASAMXAXMMSXMAMXSASMMMMAMAAXAXMSAMXSAASMMAMSXSASX
+XXAXAMXXSMMMMMSMSMMMSMMMMMMXMAAMMMAASAMAXXXAAAMXSMMMAMMMMASMMMMSAMASMXSASAAAXAMXAMAAMMMMAAAXMMAMMSMSMXMSMSAXAXSAMXXASAMXMASASAMMXMAMMXAAXAAM
+MSMMMSXMXXMSAMAMAXMASXMAXAXXMSSSMMMMMAMMSMSSSMXASMSMXMAMSAXAAMAXAMMSMAMAMAMXMAASXSSSMAASXSMSXSSMAAAXMAMAAMMSMSAMXASXMXSASAMXMASMSSMMSMMMMXMA
+MAXXAMMMAAXASXSSSMMASASMSMXSAAAAXSMXSXMXMAXMAMMASAAMXSAMMSSSMMSSXMXXMAMSMSMAAXAAAXMAXMMSXAMAMAXMSMMMMMMMMMXAXMAMXMMXMMXMASXMMXXAAMAXSAMXSAXM
+SASMAMSMMSMXMMMAXXMAXMMAAASMMMSMMSMAXSMAMSMXAXMAMXAMAMXXAAMASAMAMSXSMMSAAAMMSSMMXMSAMMMMXXMASMMMMAAAXAXMASXMMSASAMXAXAMSAMSAXAMMMSSMSAMAXAMX
+MASXMAAXAAMASMMAMXMSSMMMMMMAAMAXAMMMXMMASAMMAMMXSSSMXSAMMMSAMXMAMMAAASXMSMSMXMASMAMASMAMXXXAMMAAMMSMSXSAAXAAAXXXXMXAXSMSAAASMXSMAAAMSXMXSMSS
+XMXAMSSSSMSASAMMXAAAAASMSMSMMSAMXSASASMMSAMSSMSSMAMMAXMXSXMXSAMMXMMMMMAMAAAMMXMSAMSAMMAMMSMSSSSXSAAXXAAMASMMMSSXSMSSXXASMXSXMAXMMSMMMMSXAAAX
+MMMXMXAAMXMXXMSASMMMSMMAMAAXXMASXSASASAXMMMMAAXAMAMMMSMXSAMAXMASMMSAXXSMMSXMXSXXMAMXSSMSAAAXAAAMMMMSMXMMASAXMXMAMAAXAMAXAXXAMSMMXMXSAAXSMMMS
+AXMASMMXMMSSMXXMAMXAAAMSMMMXXXAMXSXMAMMSAXSSMMMASXSXMSAAMAMXSXAAAASXSMXXXMAMSMSAMXAAXAMMXSMMMMXMASXSXMXSASMMSAMAMMMSXMSMMMXAMAAXAMASMSXMMAMA
+XSMMXXMMMXAASAMXMMSSSMMAMXSAMSSXMSAMXMXMXMXXAMSXSAAAMXMASXMMMXAMMMMASMXMXMAMAAAMXSXMMXMAXMAASASMAXXXAXXMASMASAMXMAAMAMMAMASXMSMMXSAXMMAMXMXA
+MSASMMXAXMSMMXMAXXAAMASXSAMAMAMMMSAMXSASAMXSXMMAMMMSXMXMAMAASASMXMMXMMAXASASMSMMAAAXXSMSSSMMSASMMXSSMMMMAMMMSAMSSMMSAMMXMMMAAAMAMMMXMSAMMSMX
+ASAMXAXSSXMASMSSSMMSMAMAMMMAMASXAXXMASASASAXAMMXMSAMASXMAMXMAAXAAXSMMSSMXSASAMAMXSAMAAAMXXXAMAMAAAXXSASMAMXAMAMAAAASMSMSMSSMSMMMSAMAAXAMXAAM
+XMAMMSMAAMSAMAAAAXXXMAMMMXSXSASMMSXSAMXMAMXMMMAAAMAXAMXMASMXMAMSXMSAMAAAMMXMMSAMAXAMXMXMASMMMSSMMMSASXSSXSAXSMMSSMMMXAMXAMAXMAMMSASXSMMSSMSX
+MSAMAAMMMMMSSSMSMMMMSXSAMAAAMASAAAMMXSSSSXSXMAXMSSSMSSXMMSAASXMMMXSSMMMMSAAXAMMSMXXMAMXMMSAMXXAXAXMXMAXAMMMMXMMAMMXSSMSMMMMXMAMXMXMAAAXAAMAX
+XSAMSXSAXSAAXAAXXSAAXASMSSSXMASMMSMXMAXAAAMASMSMAAMAMXMXMSMMXAAMXAMXSXAAXXMSMSMXMAMXASXMASMMMMMMMMMAMSMMMAMSAXMXXSAMMAXMXSXSXXXAXMMSSMMSSMAS
+ASAMXXXASMMXSXMMASAMSAMXAMAXMASMAAASMMMMMMMAMAAMMMMAMMMSMMXXSSMAMMSAMSMSMMMXXAMAMAMSAMAMASXMAAXAXXXAXASMMAMMXXMXMMASMMXMASXSAXSMSAMAMAAXXMAS
+MMXXXMSMMAAMMXXMAMAXMMMMSSMSMMSMMXAXAAAXAAMASXSMXSSSMSAXAXSAXASAAXMAXXMAMAMXSAXAXAMXAMXMASAMSXSAASMMSAMSMSMMSSXMASAMAXAMAXAMXMAAXAMXMSMMAMAS
+XAXSMAAMMXMAAASMXSAMXSAMXAXSAMXMAXSSMSAMMXMMXAAAAAAXAMMSXMMMSAMMSAXMMXXAXMSAMMSSSSMSSMXSASMXAAMXMXAAMMMSMXAMXAASXMMSAAXMMSXSASMMMSXMAMASXMAS
+MMSMASMXXAXMXMXAAXASASASXSMSAMAMMSMAXMASMSSSMSMMMSMMSMXXMAAAAXXAAAASASXSSMMASAAAAAAXMAXMASXMMMMAXMMMMXXMASXMMSMMAMMXMASMXAMMASMMMAASASAMXMAX
+MXAXMAMXSMSAMXMMMSMMASAMXXAXAMXAMMXMMMMAAAAXMAMXXXXAAMXSAXASMSASMXMMASMMAMSAMXSMXMMMASXMAMMXAASXSXAXMXXMXMXSXAXSXMAAXMAMMXSMAMAAMMAMAMXMXMMM
+SSSSXSXMAAAMAAMAXXAMAMMMMMAMSMSSSMASASASMMMMSMSSXAMSSSMMSXAAAXMAMAXMAMASAMXXMAXXXSSSMAMSXSAMSXMAMXMMSMASAXXXXMMMMSSSSMAMXSXMASMMSXAMXMAMAAAA
+XAXMAMSAMXMSSXSAXXMMXSMMASAMAAAXAXMSASAXMSSMSXAMAMXMAMAAXMMMXMXXXMMMMAMXXMASMASXAMAAXMMMAMXXMAMXMMSAAAMSASXSMSAAAMAAXXASXMAMAAAXMMMMAMAMXXAS
+MAMAASAMXSXAMAMXSMMAXAASASAXXMMXSMMMMMXMASAASMAXAMXXAMSMMAXAMSMSASMSMSXSAMXXMASXMMXMMXAMAXMXMAAXMAMMXSAMAMXSASMMSSMSMSMSAMAMSSMASXMSSSSSMSAA
+MXASXSASAXMASMAMAAMMSSMMXSMMSASXAMSSSMSAXSMMMSASMXSMXXAASAMXSAAMAMAAAAXAMXSXMXSASXSSXSASAMXMSASMMSSMSXMMAMXMAMAXAAXMASAMXSMMAAAAAAAAXAAAAXAM
+MXMMASAMXMAXAAAAXXMAAAMMMXMASAMSMMAAAAMSXMXXAMXXAASAMSSMMSMXMMSMSMXMMMSXMASMMAMAMAAXMMAMXAMXMSAAXMAMSAXSXSASASAMSSMSSXAXAAXMSMMMSMMMSMMMMXAX
+XMMMMMMMAASAMSSSSMMMSXXXXXMXMAMMXMMSMMMMMMAMXSSMMMMAMMAMAAXXMXAXMASXXAAAMAMAMXMSMMMMXAAMXSAMXMXSMSSMSXMXMSMSAMMXXMAXMMMMMSSXXXMAXXXXAXMMSSMM
+MAXSSXMSXSMMXMAAAXXXMMSMSMXXSAMXXMXMAXXAAMXSAAMMXXMSMMAMMSMMSMSMSMAMMMSXMSMSAMXXAXMSSMXSAMXMXSAMXMXAMMXAMMAMMMSXXMSMSMMAXAXAMXMMSMMXMMMAAAAX
+ASMXSAAXMXMASMMSMMXMAXAAMSAXMXMASXMXMASMMSAMMSMMXSXXASMMXAXMAAAAAAAXAXMMMXAAMMMSMMSAMAMMXMAXAMMXXMMSMMSSSMAMAXXAXXAAXMASXXMSMXSAAAASMSMMSSSM
+MXMMSMMSXSMAMSAXAMXMSSMMMXXSMAMAMAMSSMSAAMXMMMAMASMAMMAASAXMAXMSMSMSMXMAAMXMMAXAAXMAMSMAAMMMMSSMSMAAAXSAMXMMAMXMMSMSMMAXAMXAXAMSSSMMAAMAMAMA
+ASAMXMASMMMSSMSSSSSMAAMSMMMAMAMAMAMMAXXMXMMMAXXMAMMAMAXMMASXSMAXAAAAASXSMSMSSXSMSXSXMAMSMSASAAAXXMSSSMMAMXXMMSAXMXXAAMXSAMXMMMMMXAMMXMMMMMMA
+XSAMAMAXAXMMAAASAAAMSSMAAAAMSAXSXSMXMSMSAMSSMXAMXSMXMXSMXXMAMXAMSMSMSMAAXMAMXAXXMASMSXMAXMAMMSMSAMAAMASXMASXMSASXMMSSMMAMMAXAAAMSMMSMMMXASXS
+ASAMXMAXSMMSMMMMMSMMMAXSSMMXMAXXAMSMXAMXASXAAASXAMASXMMAXMAMXAXAXMXXMMSMMMMMXXSSMMMXMXAMMMSMMAXSAMMSMXAMMAXMAMAMXAAAAAXXMSXMXXXXAMXAAXASXSAM
+XSAMXMMMMAXSXSSXXAMAMXAMXAASMMSMAMASMASXMMXMMMXAMMAMAASMXXMMXSSSXMMXMAMXMSAMXXMAMSXMAMXAMMXASMXSAMXXMMMAMASXXMMMSMMSSSMMASXSASXMSAMMSMMXMMAM
+MSAMMAMASXMXAAMXMSMMSMMSMSMSAAXMXMAMXAMXMAMXAXAMXMSSSMMMMSMMAMAMAAAAMXSAASASMXSAMMAMAASXSMSMMXMSXMXXAAXXSASMASMAMAMAMXAXAXAMASMAAMAMMXMAAMXM
+ASMMAXSASAMMSMMSMASAAXXAAAASMMMSMMMSAMXAMASMMMMMXSAMXMAXAAAMXSMSXMSXXAMXMMXAAXAASAMXMXMAAASMSMMMAMASMMSXMAMMAMMAMMMSMMSMMSMMAMMSMXSXMASXMXAX
+XXMASXMXSAMMAXAAXMASMSAMXMXMASXMAXAXAMSSXXXAMASAMXMXASMMSSSMAMXMMMAAMSAMXMSSSMMXMAMXSAMXMAMAXXASAMXXAAMAMAMMXSXMXSAMAAXMXSXAMXAXXAMMSMMAMSXM
+AAXXAMMASXSSMMSSXSAAXMAXXXAAXMASAMSSSMAMMSSXMASAASXMXSAAAMAMSMAMAMMXMAAAXAAAXMXSSMMASASAMSMXMSXSMXSXMMMXMAMMMSAAXMASMMXSAMASXMASMXXMAMMAXMAM
+SXMASAMASAMAAAAAAMSMSAMXSSMXSXXMAMMAMMXMAMAXMMSMMSAXMSMMMSXMAAMMSSXASXMMMMXSMMAAAAMMSAMXSXSAASAMMASMAAXXMXSAAXMMMMMMAMSMMSAMAMSXMAXSMXSMXMAA
+XMAAAXMASMSSMMMMMMMXSAMXAXMASMSSSMMAMSMMSSMXXMXMXSAMAMXMASASMMXAAMXXMAAXXMAMAMXSSMMMMMMXMASMAMAMMASASMSMSASMSSXMASASAMAAAMASXMXAMSXMXXAMXSXM
+MAMXXXSXSXMMXAMASXMASAMXMXSAXAMAAXMAMMMAMAXSMMMMMMSAMXAXMXXAXAMSSSSSSSMMAMAMSMMXMASAAAMAMXMMASAMMMSAXAXXMAMAAXMXMSASXSMMMSAMXSMMMXAMASASMMSM
+ASMMSASAMMMMSXSASAXXXMAXXMMAMSMSMSSSMSMSXMMMAAXMAAAMMXMSMSMMMMMAAMAXAXMSASXSAMMASXMMSMSMSMXSASASXXMAMXMMMSMMMSSMMMXMAXXAXMASAXXXAMAMXSAMMAAX
+MXAASAMAMAAXMXMASMMMSAMXMSSSMAMMAMAMASAMASMSSMSSMXMMSAAXAASAAMMMSMMMASXMASXAAXMASAXAMXAAMAXMMSAMXAMMMASAAXASAMXASXSMSMSMSSMMMMXMSSSMXMAMMSSX
+XSMMMASMMSSXSAMXMAAMASXXMAAASXMMSMAMMMASAMXAASAXXXSASMMMSMSMSSXXAMXMXMASXMASMMMASXMASXMMMXSAAMAMSMAAAASMXSAMSSSMMASAAAAMMAXMAMXAXAAMAMAMXAXX
+AXXXSXMAXXMXSSSMSSMSXMSSMMSMMMXXXAMXSMXMXMMSSMSMSAMXSAMXXXXMMMMAMXXXSSXMXSAMXXMXMXAXXMASXMSMMSMMSXSAMMSXMMMSXMAXMAMXMSMXSAMSXSXSMSMMXSASMASX

+ 128 - 0
aoc2024/day5/README.md

@@ -0,0 +1,128 @@
+--- Day 5: Print Queue ---
+--------------------------
+
+Satisfied with their search on Ceres, the squadron of scholars suggests subsequently scanning the stationery stacks of sub-basement 17.
+
+
+The North Pole printing department is busier than ever this close to Christmas, and while The Historians continue their search of this historically significant facility, an Elf operating a [very familiar printer](/2017/day/1) beckons you over.
+
+
+The Elf must recognize you, because they waste no time explaining that the new *sleigh launch safety manual* updates won't print correctly. Failure to update the safety manuals would be dire indeed, so you offer your services.
+
+
+Safety protocols clearly indicate that new pages for the safety manuals must be printed in a *very specific order*. The notation `X|Y` means that if both page number `X` and page number `Y` are to be produced as part of an update, page number `X` *must* be printed at some point before page number `Y`.
+
+
+The Elf has for you both the *page ordering rules* and the *pages to produce in each update* (your puzzle input), but can't figure out whether each update has the pages in the right order.
+
+
+For example:
+
+
+
+```
+47|53
+97|13
+97|61
+97|47
+75|29
+61|13
+75|53
+29|13
+97|29
+53|29
+61|53
+97|53
+61|29
+47|13
+75|47
+97|75
+47|61
+75|61
+47|29
+75|13
+53|13
+
+75,47,61,53,29
+97,61,53,29,13
+75,29,13
+75,97,47,61,53
+61,13,29
+97,13,75,29,47
+
+```
+
+The first section specifies the *page ordering rules*, one per line. The first rule, `47|53`, means that if an update includes both page number 47 and page number 53, then page number 47 *must* be printed at some point before page number 53. (47 doesn't necessarily need to be *immediately* before 53; other pages are allowed to be between them.)
+
+
+The second section specifies the page numbers of each *update*. Because most safety manuals are different, the pages needed in the updates are different too. The first update, `75,47,61,53,29`, means that the update consists of page numbers 75, 47, 61, 53, and 29.
+
+
+To get the printers going as soon as possible, start by identifying *which updates are already in the right order*.
+
+
+In the above example, the first update (`75,47,61,53,29`) is in the right order:
+
+
+* `75` is correctly first because there are rules that put each other page after it: `75|47`, `75|61`, `75|53`, and `75|29`.
+* `47` is correctly second because 75 must be before it (`75|47`) and every other page must be after it according to `47|61`, `47|53`, and `47|29`.
+* `61` is correctly in the middle because 75 and 47 are before it (`75|61` and `47|61`) and 53 and 29 are after it (`61|53` and `61|29`).
+* `53` is correctly fourth because it is before page number 29 (`53|29`).
+* `29` is the only page left and so is correctly last.
+
+
+Because the first update does not include some page numbers, the ordering rules involving those missing page numbers are ignored.
+
+
+The second and third updates are also in the correct order according to the rules. Like the first update, they also do not include every page number, and so only some of the ordering rules apply - within each update, the ordering rules that involve missing page numbers are not used.
+
+
+The fourth update, `75,97,47,61,53`, is *not* in the correct order: it would print 75 before 97, which violates the rule `97|75`.
+
+
+The fifth update, `61,13,29`, is also *not* in the correct order, since it breaks the rule `29|13`.
+
+
+The last update, `97,13,75,29,47`, is *not* in the correct order due to breaking several rules.
+
+
+For some reason, the Elves also need to know the *middle page number* of each update being printed. Because you are currently only printing the correctly-ordered updates, you will need to find the middle page number of each correctly-ordered update. In the above example, the correctly-ordered updates are:
+
+
+
+```
+75,47,*61*,53,29
+97,61,*53*,29,13
+75,*29*,13
+
+```
+
+These have middle page numbers of `61`, `53`, and `29` respectively. Adding these page numbers together gives `*143*`.
+
+
+Of course, you'll need to be careful: the actual list of *page ordering rules* is bigger and more complicated than the above example.
+
+
+Determine which updates are already in the correct order. *What do you get if you add up the middle page number from those correctly-ordered updates?*
+
+
+--- Part Two ---
+----------------
+
+While the Elves get to work printing the correctly-ordered updates, you have a little time to fix the rest of them.
+
+
+For each of the *incorrectly-ordered updates*, use the page ordering rules to put the page numbers in the right order. For the above example, here are the three incorrectly-ordered updates and their correct orderings:
+
+
+* `75,97,47,61,53` becomes `97,75,*47*,61,53`.
+* `61,13,29` becomes `61,*29*,13`.
+* `97,13,75,29,47` becomes `97,75,*47*,29,13`.
+
+
+After taking *only the incorrectly-ordered updates* and ordering them correctly, their middle page numbers are `47`, `29`, and `47`. Adding these together produces `*123*`.
+
+
+Find the updates which are not in the correct order. *What do you get if you add up the middle page numbers after correctly ordering just those updates?*
+
+

+ 166 - 0
aoc2024/day5/day5.go

@@ -0,0 +1,166 @@
+package main
+
+import (
+	"bufio"
+	"flag"
+	"fmt"
+	"os"
+	"strconv"
+	"strings"
+)
+
+func main() {
+	args := flag.Bool("example", false, "example or input")
+	flag.Parse()
+	filename := "input.txt"
+	if *args {
+		filename = "example.txt"
+	}
+	file, err := os.Open(filename)
+	if err != nil {
+		fmt.Println(err)
+		return
+	}
+	defer file.Close()
+
+	scanner := bufio.NewScanner(file)
+	var rules []string
+	var updates [][]int
+	readingRules := true
+
+	for scanner.Scan() {
+		line := strings.TrimSpace(scanner.Text())
+		if line == "" {
+			readingRules = false
+			continue
+		}
+		if readingRules {
+			rules = append(rules, line)
+		} else {
+			update := parseUpdate(line)
+			updates = append(updates, update)
+		}
+	}
+
+	if err := scanner.Err(); err != nil {
+		fmt.Println(err)
+		return
+	}
+
+	orderRules := parseRules(rules)
+
+	totalSum := 0
+	totalCorrectedSum := 0
+	for _, update := range updates {
+		if isValidUpdate(update, orderRules) {
+			middle := findMiddlePage(update)
+			totalSum += middle
+		} else {
+			// fmt.Println("us", update)
+			correctedUpdate := orderUpdate(update, orderRules)
+			// fmt.Println("cc", correctedUpdate, "\n")
+			totalCorrectedSum += findMiddlePage(correctedUpdate)
+		}
+	}
+
+	fmt.Println("Total Sum:", totalSum)
+	fmt.Println("Total Corrected Sum:", totalCorrectedSum)
+}
+
+func parseRules(rules []string) map[int][]int {
+	ruleMap := make(map[int][]int)
+	for _, rule := range rules {
+		parts := strings.Split(rule, "|")
+		x, _ := strconv.Atoi(parts[0])
+		y, _ := strconv.Atoi(parts[1])
+		ruleMap[x] = append(ruleMap[x], y)
+	}
+	return ruleMap
+}
+
+func parseUpdate(line string) []int {
+	parts := strings.Split(line, ",")
+	var update []int
+	for _, part := range parts {
+		num, _ := strconv.Atoi(strings.TrimSpace(part))
+		update = append(update, num)
+	}
+	return update
+}
+
+func isValidUpdate(update []int, rules map[int][]int) bool {
+	position := make(map[int]int)
+	for i, page := range update {
+		position[page] = i
+	}
+
+	for x, ys := range rules {
+		for _, y := range ys {
+			posX, existsX := position[x]
+			posY, existsY := position[y]
+			if existsX && existsY && posX >= posY {
+				return false
+			}
+		}
+	}
+	return true
+}
+
+func orderUpdate(update []int, rules map[int][]int) []int {
+	// we have overkill topological sort here, fuck yeah.
+
+	graph := make(map[int][]int)
+	inDegree := make(map[int]int)
+	pageSet := make(map[int]bool)
+
+	for _, page := range update {
+		pageSet[page] = true
+		inDegree[page] = 0
+	}
+
+	for x, ys := range rules {
+		if !pageSet[x] {
+			continue
+		}
+		for _, y := range ys {
+			if pageSet[y] {
+				graph[x] = append(graph[x], y)
+				inDegree[y]++
+			}
+		}
+	}
+
+	var ordered []int
+	queue := []int{}
+
+	for _, page := range update {
+		if inDegree[page] == 0 {
+			queue = append(queue, page)
+		}
+	}
+
+	for len(queue) > 0 {
+		current := queue[0]
+		queue = queue[1:]
+		ordered = append(ordered, current)
+
+		for _, neighbor := range graph[current] {
+			inDegree[neighbor]--
+			if inDegree[neighbor] == 0 {
+				queue = append(queue, neighbor)
+			}
+		}
+	}
+
+	if len(ordered) != len(update) {
+		fmt.Println("len corrected doesn't match", len(ordered), len(update))
+		return nil
+	}
+
+	return ordered
+}
+
+func findMiddlePage(update []int) int {
+	mid := len(update) / 2
+	return update[mid]
+}

+ 0 - 0
aoc2024/day5/day5.py


+ 28 - 0
aoc2024/day5/example.txt

@@ -0,0 +1,28 @@
+47|53
+97|13
+97|61
+97|47
+75|29
+61|13
+75|53
+29|13
+97|29
+53|29
+61|53
+97|53
+61|29
+47|13
+75|47
+97|75
+47|61
+75|61
+47|29
+75|13
+53|13
+
+75,47,61,53,29
+97,61,53,29,13
+75,29,13
+75,97,47,61,53
+61,13,29
+97,13,75,29,47

+ 1387 - 0
aoc2024/day5/input.txt

@@ -0,0 +1,1387 @@
+24|55
+38|32
+38|21
+48|51
+48|92
+48|14
+78|35
+78|54
+78|87
+78|44
+72|29
+72|65
+72|87
+72|82
+72|37
+23|56
+23|51
+23|81
+23|83
+23|25
+23|87
+25|14
+25|18
+25|55
+25|22
+25|15
+25|77
+25|17
+54|96
+54|65
+54|33
+54|21
+54|36
+54|29
+54|56
+54|89
+56|78
+56|88
+56|77
+56|52
+56|22
+56|81
+56|14
+56|85
+56|17
+33|23
+33|22
+33|83
+33|14
+33|89
+33|25
+33|55
+33|92
+33|72
+33|78
+96|78
+96|21
+96|14
+96|77
+96|92
+96|68
+96|88
+96|24
+96|83
+96|55
+96|91
+97|56
+97|54
+97|17
+97|43
+97|13
+97|33
+97|48
+97|96
+97|65
+97|89
+97|83
+97|37
+35|92
+35|23
+35|25
+35|52
+35|24
+35|33
+35|51
+35|21
+35|55
+35|88
+35|17
+35|56
+35|89
+52|44
+52|61
+52|88
+52|82
+52|64
+52|71
+52|51
+52|99
+52|97
+52|68
+52|85
+52|91
+52|18
+52|55
+22|43
+22|61
+22|72
+22|68
+22|15
+22|87
+22|64
+22|85
+22|97
+22|88
+22|51
+22|71
+22|18
+22|63
+22|91
+29|14
+29|81
+29|35
+29|89
+29|96
+29|21
+29|13
+29|36
+29|23
+29|65
+29|48
+29|17
+29|24
+29|52
+29|33
+29|99
+65|17
+65|15
+65|25
+65|48
+65|56
+65|22
+65|52
+65|21
+65|92
+65|23
+65|36
+65|83
+65|24
+65|55
+65|37
+65|89
+65|81
+36|77
+36|96
+36|83
+36|99
+36|56
+36|89
+36|68
+36|21
+36|55
+36|92
+36|78
+36|88
+36|51
+36|72
+36|52
+36|14
+36|24
+36|17
+32|24
+32|83
+32|13
+32|29
+32|21
+32|25
+32|92
+32|56
+32|33
+32|99
+32|96
+32|14
+32|35
+32|22
+32|88
+32|17
+32|65
+32|81
+32|37
+64|42
+64|48
+64|37
+64|96
+64|44
+64|56
+64|71
+64|76
+64|36
+64|29
+64|33
+64|23
+64|65
+64|13
+64|25
+64|38
+64|43
+64|32
+64|97
+64|54
+55|64
+55|76
+55|61
+55|43
+55|38
+55|87
+55|71
+55|72
+55|54
+55|68
+55|18
+55|67
+55|85
+55|63
+55|51
+55|78
+55|77
+55|44
+55|15
+55|97
+55|91
+43|14
+43|96
+43|32
+43|89
+43|48
+43|35
+43|23
+43|36
+43|83
+43|24
+43|33
+43|52
+43|56
+43|65
+43|13
+43|25
+43|21
+43|17
+43|54
+43|76
+43|42
+43|37
+92|85
+92|71
+92|38
+92|77
+92|64
+92|76
+92|44
+92|51
+92|63
+92|68
+92|87
+92|55
+92|88
+92|18
+92|99
+92|15
+92|72
+92|97
+92|43
+92|82
+92|61
+92|91
+92|78
+17|18
+17|81
+17|82
+17|52
+17|92
+17|77
+17|64
+17|21
+17|14
+17|68
+17|51
+17|83
+17|99
+17|24
+17|91
+17|72
+17|88
+17|15
+17|87
+17|85
+17|55
+17|22
+17|67
+17|78
+83|68
+83|77
+83|18
+83|99
+83|67
+83|51
+83|15
+83|72
+83|92
+83|22
+83|82
+83|85
+83|88
+83|63
+83|78
+83|44
+83|52
+83|24
+83|91
+83|55
+83|87
+83|61
+83|14
+83|64
+76|25
+76|14
+76|56
+76|22
+76|89
+76|23
+76|42
+76|35
+76|83
+76|29
+76|48
+76|32
+76|81
+76|33
+76|96
+76|13
+76|65
+76|21
+76|36
+76|52
+76|24
+76|17
+76|37
+76|54
+67|32
+67|71
+67|33
+67|25
+67|56
+67|97
+67|42
+67|43
+67|38
+67|37
+67|64
+67|29
+67|76
+67|35
+67|48
+67|44
+67|36
+67|82
+67|54
+67|23
+67|61
+67|63
+67|65
+67|13
+71|25
+71|48
+71|29
+71|33
+71|96
+71|42
+71|17
+71|89
+71|97
+71|35
+71|37
+71|54
+71|23
+71|43
+71|83
+71|36
+71|21
+71|13
+71|38
+71|76
+71|81
+71|65
+71|56
+71|32
+42|22
+42|35
+42|29
+42|24
+42|92
+42|36
+42|32
+42|99
+42|89
+42|14
+42|48
+42|65
+42|56
+42|17
+42|37
+42|96
+42|23
+42|25
+42|13
+42|21
+42|52
+42|81
+42|33
+42|83
+51|67
+51|78
+51|61
+51|71
+51|63
+51|97
+51|42
+51|87
+51|72
+51|77
+51|18
+51|29
+51|15
+51|64
+51|85
+51|82
+51|44
+51|43
+51|68
+51|54
+51|38
+51|76
+51|91
+51|32
+85|61
+85|67
+85|76
+85|25
+85|37
+85|33
+85|36
+85|32
+85|23
+85|97
+85|43
+85|63
+85|38
+85|35
+85|13
+85|48
+85|29
+85|44
+85|64
+85|82
+85|65
+85|42
+85|54
+85|71
+81|82
+81|72
+81|52
+81|87
+81|91
+81|15
+81|14
+81|83
+81|92
+81|22
+81|78
+81|68
+81|77
+81|18
+81|24
+81|67
+81|51
+81|85
+81|64
+81|99
+81|88
+81|55
+81|61
+81|21
+63|29
+63|44
+63|38
+63|89
+63|36
+63|48
+63|25
+63|33
+63|96
+63|17
+63|81
+63|32
+63|43
+63|42
+63|35
+63|37
+63|13
+63|76
+63|56
+63|97
+63|54
+63|65
+63|71
+63|23
+37|22
+37|56
+37|99
+37|36
+37|33
+37|78
+37|92
+37|23
+37|52
+37|14
+37|24
+37|55
+37|13
+37|48
+37|25
+37|81
+37|89
+37|83
+37|21
+37|96
+37|15
+37|17
+37|88
+37|51
+15|67
+15|61
+15|29
+15|77
+15|76
+15|68
+15|97
+15|71
+15|85
+15|32
+15|64
+15|63
+15|54
+15|35
+15|87
+15|91
+15|38
+15|43
+15|78
+15|42
+15|44
+15|82
+15|18
+15|72
+82|71
+82|54
+82|36
+82|65
+82|61
+82|63
+82|35
+82|96
+82|32
+82|33
+82|48
+82|76
+82|97
+82|56
+82|29
+82|43
+82|89
+82|23
+82|38
+82|25
+82|42
+82|37
+82|44
+82|13
+88|42
+88|78
+88|71
+88|15
+88|44
+88|54
+88|51
+88|85
+88|97
+88|43
+88|72
+88|91
+88|76
+88|87
+88|18
+88|64
+88|82
+88|63
+88|77
+88|38
+88|67
+88|68
+88|55
+88|61
+14|85
+14|77
+14|68
+14|87
+14|55
+14|67
+14|44
+14|99
+14|22
+14|91
+14|92
+14|61
+14|38
+14|64
+14|71
+14|15
+14|72
+14|52
+14|51
+14|82
+14|63
+14|78
+14|88
+14|18
+18|65
+18|64
+18|71
+18|38
+18|33
+18|63
+18|43
+18|61
+18|67
+18|91
+18|37
+18|13
+18|82
+18|29
+18|48
+18|97
+18|44
+18|42
+18|23
+18|35
+18|85
+18|54
+18|76
+18|32
+77|54
+77|68
+77|97
+77|63
+77|67
+77|85
+77|37
+77|42
+77|38
+77|61
+77|72
+77|18
+77|65
+77|29
+77|44
+77|35
+77|91
+77|82
+77|43
+77|71
+77|32
+77|76
+77|87
+77|64
+44|38
+44|35
+44|25
+44|36
+44|29
+44|33
+44|89
+44|76
+44|56
+44|37
+44|23
+44|48
+44|96
+44|65
+44|97
+44|43
+44|54
+44|71
+44|17
+44|21
+44|81
+44|42
+44|32
+44|13
+21|61
+21|22
+21|14
+21|82
+21|72
+21|92
+21|91
+21|18
+21|15
+21|24
+21|87
+21|67
+21|83
+21|55
+21|85
+21|99
+21|77
+21|63
+21|68
+21|51
+21|88
+21|64
+21|52
+21|78
+87|37
+87|65
+87|64
+87|48
+87|67
+87|91
+87|33
+87|82
+87|29
+87|63
+87|54
+87|85
+87|42
+87|61
+87|76
+87|38
+87|97
+87|44
+87|35
+87|43
+87|32
+87|18
+87|13
+87|71
+89|87
+89|81
+89|92
+89|78
+89|15
+89|88
+89|64
+89|91
+89|17
+89|68
+89|24
+89|72
+89|77
+89|99
+89|55
+89|83
+89|22
+89|18
+89|14
+89|52
+89|21
+89|85
+89|51
+89|67
+61|63
+61|97
+61|33
+61|23
+61|65
+61|17
+61|35
+61|13
+61|56
+61|71
+61|44
+61|96
+61|42
+61|38
+61|37
+61|29
+61|76
+61|48
+61|32
+61|54
+61|36
+61|43
+61|89
+61|25
+91|65
+91|67
+91|44
+91|13
+91|76
+91|32
+91|61
+91|82
+91|63
+91|85
+91|29
+91|43
+91|36
+91|64
+91|48
+91|71
+91|38
+91|37
+91|33
+91|42
+91|97
+91|35
+91|23
+91|54
+68|87
+68|65
+68|63
+68|91
+68|38
+68|37
+68|61
+68|35
+68|54
+68|32
+68|82
+68|97
+68|18
+68|71
+68|13
+68|72
+68|64
+68|85
+68|44
+68|42
+68|29
+68|76
+68|43
+68|67
+99|91
+99|15
+99|38
+99|55
+99|72
+99|64
+99|77
+99|18
+99|97
+99|54
+99|76
+99|61
+99|78
+99|44
+99|71
+99|68
+99|82
+99|43
+99|51
+99|88
+99|85
+99|63
+99|67
+99|87
+13|15
+13|14
+13|99
+13|89
+13|17
+13|21
+13|25
+13|51
+13|56
+13|33
+13|48
+13|36
+13|78
+13|83
+13|77
+13|81
+13|24
+13|52
+13|88
+13|23
+13|22
+13|55
+13|92
+13|96
+24|18
+24|87
+24|77
+24|92
+24|52
+24|14
+24|44
+24|61
+24|22
+24|71
+24|82
+24|72
+24|78
+24|68
+24|64
+24|63
+24|51
+24|67
+24|88
+24|99
+24|15
+24|85
+24|91
+38|43
+38|65
+38|54
+38|42
+38|23
+38|33
+38|76
+38|83
+38|96
+38|25
+38|37
+38|48
+38|35
+38|81
+38|56
+38|97
+38|29
+38|13
+38|36
+38|89
+38|24
+38|17
+48|33
+48|83
+48|23
+48|78
+48|55
+48|81
+48|22
+48|77
+48|89
+48|25
+48|24
+48|21
+48|99
+48|36
+48|17
+48|96
+48|68
+48|56
+48|52
+48|15
+48|88
+78|68
+78|72
+78|77
+78|43
+78|64
+78|38
+78|61
+78|97
+78|71
+78|76
+78|42
+78|32
+78|85
+78|65
+78|91
+78|63
+78|82
+78|18
+78|67
+78|29
+72|32
+72|67
+72|97
+72|64
+72|61
+72|13
+72|42
+72|85
+72|76
+72|71
+72|91
+72|35
+72|18
+72|54
+72|48
+72|63
+72|43
+72|38
+72|44
+23|96
+23|68
+23|92
+23|99
+23|22
+23|14
+23|89
+23|72
+23|77
+23|17
+23|24
+23|55
+23|52
+23|15
+23|78
+23|88
+23|36
+23|21
+25|72
+25|51
+25|52
+25|21
+25|92
+25|78
+25|87
+25|91
+25|24
+25|88
+25|96
+25|83
+25|99
+25|81
+25|68
+25|89
+25|56
+54|83
+54|22
+54|81
+54|42
+54|48
+54|92
+54|24
+54|25
+54|13
+54|35
+54|52
+54|37
+54|32
+54|14
+54|23
+54|17
+56|68
+56|24
+56|99
+56|72
+56|15
+56|55
+56|51
+56|18
+56|21
+56|91
+56|87
+56|92
+56|83
+56|89
+56|96
+33|56
+33|99
+33|96
+33|52
+33|81
+33|88
+33|15
+33|36
+33|68
+33|77
+33|17
+33|51
+33|24
+33|21
+96|72
+96|52
+96|67
+96|51
+96|85
+96|81
+96|89
+96|87
+96|18
+96|17
+96|22
+96|15
+96|99
+97|42
+97|29
+97|14
+97|36
+97|81
+97|32
+97|23
+97|21
+97|35
+97|76
+97|24
+97|25
+35|65
+35|22
+35|99
+35|37
+35|13
+35|96
+35|81
+35|36
+35|14
+35|48
+35|83
+52|92
+52|15
+52|78
+52|63
+52|67
+52|22
+52|72
+52|38
+52|87
+52|77
+22|92
+22|78
+22|99
+22|82
+22|44
+22|67
+22|77
+22|38
+22|55
+29|55
+29|92
+29|56
+29|88
+29|22
+29|83
+29|25
+29|37
+65|14
+65|99
+65|88
+65|13
+65|51
+65|96
+65|33
+36|81
+36|87
+36|25
+36|15
+36|22
+36|18
+32|36
+32|48
+32|89
+32|23
+32|52
+64|82
+64|63
+64|61
+64|35
+55|32
+55|42
+55|82
+43|81
+43|29
+92|67
+
+42,54,21,36,22,33,13,29,35
+83,67,22,14,78,99,18,92,15,77,52,68,82,55,21,61,85,91,51,64,72,24,88
+85,67,64,82,61,63,44,71,38,97,43,54,42,32,29,35,65,37,13,48,33,23,36
+96,81,21,14,52,99,88,55,51,15,77,68,72,18,85
+63,52,77,85,91,83,22,61,14,64,82,68,51,24,55
+63,97,76,32,29,35,13,48,33,36,25,56,96,89,17
+15,99,51,88,21,83,72,56,81,18,92,52,55,17,89,96,87
+92,22,17,96,78,87,72,14,24,55,81,91,52,83,68,88,18,99,56
+87,18,61,67,64,76,72,85,97,65,91,68,32,44,29,43,37
+87,63,72,64,85,38,43,78,76,82,77,67,88,54,55
+51,77,87,85,67,61,63,44,97
+35,65,37,13,48,36,25,56,81,24,22,92,88
+85,29,32,42,35,87,43,13,63,37,71,72,82,76,91
+56,35,81,96,55,92,83
+54,68,67,77,61,18,63,76,82,55,97,15,42,91,51,38,85,43,72,87,71
+99,88,55,15,77,68,72,87,18,91,67,82,61,44,71,38,97,43,76
+14,17,81,91,55,22,21,87,64
+92,51,68,96,81,17,88,89,83,22,23,15,14,21,25,99,24,78,56,72,36,77,55
+68,87,18,85,82,44,71,43,76,54,42,32,29,35,37
+92,22,88,14,21,55,24,17,25,36,13,23,48
+92,25,18,68,88,51,17
+32,17,37,54,89,71,43,33,42,21,25
+33,36,25,56,96,89,17,81,83,24,14,52,22,92,99,55,51,15,78,77,68
+61,63,44,71,38,43,76,54,42,32,65,13,48,33,36,56,89
+14,88,51,87,64,44,71
+14,92,88,51,15,77,68,87,71
+42,21,89,83,35,65,81,24,23,32,33,13,29,14,52,25,17
+17,83,14,22,92,55,51,15,78,77,18,91,85,67,64
+21,83,22,18,92,67,15,99,64,85,68,87,55,91,78,51,88,77,14,61,52
+64,15,77,85,92,61,88,83,78,22,18,72,68,52,82,91,87,63,14,99,55
+89,21,76,35,96,83,17,13,38,25,54
+77,68,91,85,64,82,44,38,65
+54,64,91,38,63,51,71,61,85,97,44,18,67,76,43,72,78,15,32
+51,87,52,85,72,14,83,24,68,15,21,17,92
+21,83,99,96,36,17,52,81,56,65,25,14,48,13,24,92,55,23,89
+76,42,29,48,33,36,25,56,96,89,17,81,83
+77,55,22,78,87,64,61,88,67,68,71,72,51,44,52,82,99,15,14
+37,33,85,54,44,76,38,23,13,42,36
+43,25,29,13,33,38,35,97,48,56,65,32,17,54,89,81,44,37,36,23,71
+81,92,88,78,68,91,85,67,82
+56,81,21,24,14,88,55,51,77,68,91
+97,29,65,33,17,83,24
+38,33,56,43,61,35,76,54,64,32,36
+63,44,71,38,43,76,54,42,37,13,48,23,36
+22,17,96,89,14,92,83,37,99,88,29,21,52,48,23,81,35,24,36,13,25
+77,61,18,87,72,51,38
+24,92,99,55,51,85,44
+64,82,77,35,38
+87,51,15,88,67,52,18,82,72,77,99,71,64,22,44
+99,88,51,15,78,72,87,18,85,67,64,61,63,71,76
+23,36,25,56,96,17,81,83,14,52,92,88,55,51,78,68,72
+52,92,99,15,78,77,68,72,87,91,85,64,82,61,44,71,38
+13,23,17,14,99,55,78
+25,17,35,37,44,54,71,81,56,65,32
+38,64,55,52,87,77,71,99,88,68,18
+71,38,97,76,54,42,32,29,35,65,13,33,23,36,25,56,96,89,17,81,21
+82,91,52,83,21,18,14,77,85,61,92,64,88,51,68,99,78,22,24
+29,35,13,33,25,56,96,89,17,21,83,24,14,52,22,92,88
+91,61,14,88,18,15,55,99,82,77,64,92,78,87,71,68,51,85,72
+13,36,35,32,38,76,63,82,37,43,65,42,54,48,64,29,56,97,33
+61,88,71,68,92,55,77,63,67,51,38
+18,85,88,63,77,52,38,61,64
+89,83,99,88,55,15,78,77,68,72,87,18,91,85,67
+13,17,35,89,48,33,43,54,21,23,38,83,76
+36,25,56,96,89,17,81,21,83,24,14,52,22,92,99,88,51,15,78,77,68,72,87
+24,52,22,55,51,15,78,72,87,64,82,61,44
+55,15,78,87,18,85,63,71,38,97,54
+37,44,61,32,85,76,71,68,87
+23,65,89,56,33,21,37,22,48,17,96,25,92
+24,14,52,92,99,88,55,51,15,72,87,18,91,61,63
+24,14,22,92,99,88,51,15,78,68,72,87,18,85,64,82,61,63,44
+64,44,97,43,76,54,42,35,37,13,33,36,56
+15,87,91,67,82,61,97
+63,18,32,76,67,82,15,64,91,72,85,68,54,43,42,71,61,87,97,44,38,78,29
+48,33,25,56,96,89,81,21,14,52,22,92,99,88,55,51,15,78,77
+89,17,81,83,52,88,15,78,77,72,87
+51,55,92,77,88,72,68,24,87,89,85,99,52,14,83,81,21,91,15,17,22,18,96
+76,35,33,13,14,42,81,43,23,29,89,24,21,96,17,37,32,25,65
+89,25,13,56,78,15,92,48,17,23,88,99,14,51,52
+21,83,54,33,35,25,13,22,48,37,56,14,36,89,42
+61,71,29,37,13
+96,17,24,14,22,92,88,51,77,72,85
+99,88,55,51,77,68,72,87,18,91,85,82,61,63,71,38,97,43,76
+65,35,42,32,13,17,25,83,33,23,54,14,24
+76,54,87,72,61,18,97,91,44,42,65,85,82,71,77,35,29
+91,87,92,78,21,52,18,24,68,85,77,15,81,83,22,64,72,51,99,82,14,67,88
+43,32,35,37,13,96,17
+33,36,96,21,24,14,52,22,92
+77,83,92,85,81,91,21,68,24,64,82
+61,71,48,63,44,32,42,65,37,56,96,43,35,76,29,23,38
+44,71,38,54,32,35,13,33,23,56,96
+23,17,81,21,83,24,92,99,88,55,51,15,78,77,72
+42,33,61,67,23,64,25,65,82
+81,13,48,22,29,23,35,14,21,92,89
+33,23,36,25,56,96,17,81,21,83,24,14,52,22,92,99,88,55,51,15,78,77,68
+32,29,35,65,37,48,23,36,56,96,89,17,81,21,83,24,52,22,99
+65,37,13,25,96,89,17,21,92
+48,76,13,82,71,97,23,61,56,29,36,33,44,42,25,43,38,54,37,96,35
+21,99,61,87,68,22,88
+18,38,54,32,35,48,33
+97,63,55,78,15,77,68,87,61,18,38,51,71,91,88,99,92,22,44,85,82,67,64
+56,99,36,96,13
+56,25,43,76,23,33,64,29,36
+99,51,68,87,91,82,63,44,71,43,76
+82,54,85,91,29,64,33,61,42,37,97
+56,42,17,33,97,43,63
+77,17,21,99,52,85,15,91,78,88,14,67,51,24,92,22,64
+55,51,15,78,77,68,72,87,18,91,85,67,64,82,61,63,44,38,97,43,76,54,42
+87,78,67,18,42,61,55,82,91,71,85,97,15,72,43,76,63,44,64,38,54,77,51
+37,44,64,13,29,97,25,82,61,67,36,35,43,63,23
+33,23,25,56,96,89,17,21,83,14,52,22,92,99,88,51,78,77,68
+33,36,32,35,48,23,24,21,22,17,99,83,25,37,96,29,81,92,14,65,52
+76,32,71,42,33,82,97,36,54,44,35,13,29,43,37,63,48,96,65
+65,37,13,48,33,23,36,25,56,96,89,17,81,21,83,24,52,22,92,99,88,55,51
+42,32,29,35,37,13,48,23,36,56,96,21,83,14,52,22,92
+42,43,25,65,23,37,61,44,48,29,76,33,36,38,54,97,96,89,35
+52,99,55,51,78,18,64,82,63,71,38
+36,96,89,17,81,83,14,52,88,51,15,78,77
+96,81,51,15,99,37,24,36,13,17,33
+21,83,24,14,52,99,88,55,51,15,68,72,91,85,67,64,61
+25,51,81,22,99,56,18,52,78,14,87,92,15,77,68,83,55
+81,77,92,21,51,15,99,96,56
+71,43,65,82,54,42,13,36,25,61,23,33,35,63,67,38,76,97,37,32,29
+37,76,63,61,96,56,25,35,13,36,43,29,82,32,48,33,97
+35,52,23,14,96,42,89,21,81,83,76
+48,23,36,25,56,96,89,17,81,21,83,24,14,52,22,92,99,88,55,51,15,78,77
+44,61,85,92,91,77,15,64,51
+37,13,48,33,23,25,56,81,83,52,92,51,15
+56,78,96,88,92,36,23,17,25,52,48,99,24,89,55,21,15,81,51
+64,22,67,55,97,72,15,18,68,38,88
+85,64,68,44,54,87,76,91,82,63,88
+85,38,78,82,18,87,91,32,77,43,76,72,15,42,51
+22,92,88,72,87,91,67,82,61,44,97
+55,18,54,38,87,88,85,15,76
+83,24,14,52,22,92,88,55,51,15,78,77,68,72,18,91,85,67,64,61,63
+42,32,35,65,37,13,48,33,23,36,25,56,96,89,21,83,24,14,52,22,92
+32,17,29,83,48,14,21,25,52,42,96,33,37,65,76
+35,89,81,14,32,83,29,65,52,25,92,13,22,36,33,48,37,42,24
+81,42,35,36,89,54,71,25,32,43,76,37,38,44,65,23,17,33,56
+21,18,87,52,22,56,51,15,77,92,25,55,72,99,78,96,14,83,24
+56,25,37,81,38,89,21,43,65,83,33,36,35,96,48,42,29
+55,15,77,68,87,18,91,85,61,44,38,97,43,76,42
+22,99,72,83,67,52,61,21,68,14,87,18,77,51,64
+92,55,85,14,22,17,52,89,78
+88,68,18,14,81,22,91,52,83,99,72
+36,17,29,83,96,65,54,89,43,35,56,23,25,13,81,76,14
+88,51,78,63,43,76,54
+91,67,82,61,38,97,43,76,54,42,32,29,35,13,48,33,23
+67,63,35,71,54,68,37
+85,35,33,32,61,76,65,54,37,67,91,42,97,48,71,82,38,29,13,44,43
+77,15,81,89,96,25,14,92,78,22,51,24,21,83,56,18,88,99,68
+23,36,25,22,92,15,72
+23,25,54,36,65,17,14,76,56,96,35,48,81,24,37,21,89
+85,64,61,38,32,29,65
+56,89,17,24,14,92,99,55,78,18,91
+18,85,61,63,44,71,38,48,33
+81,21,14,52,92,88,72,67,82
+55,51,15,78,77,64,63,44,38,43,76,54,42
+76,54,48,23,96,81,83,24,52
+21,83,13,14,22,96,25,37,56,81,36,92,42,89,23,32,24,33,52,35,17
+42,13,91,38,43,82,35,18,87,29,37,85,64,67,54,32,63,76,72,61,44
+23,22,29,21,24,36,14,99,89,56,88
+77,56,15,33,48,24,81,22,92
+78,87,85,67,44,71,97,29,35
+61,15,78,63,77,71,44,68,91,87,32,85,72,43,76,82,29,97,42,54,18,38,67
+99,18,81,82,87,24,78,51,83
+54,65,48,36,14,52,22
+63,44,38,97,54,42,32,65,37,56,96,89,17
+83,88,68,72,81,52,55,36,25,22,17,92,87
+44,38,97,54,42,37,13,33,23,36,81
+61,18,67,64,38,35,65,85,68,29,37,63,71,42,91,82,97
+65,54,23,35,89,43,29,38,36,76,81,21,32,17,56,71,42
+96,78,55,91,17,77,85
+64,82,61,44,38,97,43,42,32,35,65,37,48,33,23
+23,36,25,56,89,17,81,21,83,14,52,22,92,99,88,55,51,15,78,68,72
+97,43,54,42,32,29,35,37,13,48,33,23,56,96,89,17,21,83,24
+54,65,36,23,71
+13,44,33,63,48,97,25,38,64,82,61,56,76,42,54,65,71,43,23,35,36,37,32
+65,13,48,23,36,56,89,21,52,22,88,55,51
+68,51,14,83,64,18,77,17,91
+76,37,38,25,13,33,71,21,42
+21,92,81,87,24,56,51
+48,83,35,37,81,97,89,54,33,29,36,13,96,23,38,21,65,17,76,56,32,43,25
+13,48,17,83,14,15,78
+18,22,92,82,68,87,24,52,44,99,67
+77,99,87,92,22,51,52,68,71,14,82
+22,67,83,63,14,15,82
+64,44,97,61,67,32,37,65,38,29,35,48,71,36,54,76,85
+24,14,92,99,15,78,87
+63,71,76,54,32,29,35,65,37,13,48,33,23,36,25,56,96,89,17
+42,96,71,35,25,65,23,33,44,81,32,97,29,76,13,54,43,56,17
+87,91,67,82,44,71,38,97,43,76,29,35,65,37,48
+33,38,13,48,65,43,61,82,37,76,54,32,35,44,67,29,85
+24,52,22,92,55,51,78,68,72,18,91,85,64,82,44
+63,48,85,67,38
+42,32,35,65,13,48,33,36,25,89,17,81,14
+63,44,71,43,35,65,37,13,23,36,17
+25,21,97,33,54,32,76,42,37,17,35,65,89,81,83,96,36,23,48,43,13,38,29
+42,32,29,35,65,37,33,25,56,89,17,21,24,14,52,22,92
+37,48,81,21,83,14,22,88,55,51,15
+55,51,77,68,87,18,91,85,67,82,63,44,38,97,54
+35,65,13,33,36
+61,48,44,64,43,36,82,42,56,29,23,54,33
+92,99,88,55,15,78,77,68,72,18,91,67,64,82,61,63,44,71,38,97,43
+32,29,33,23,96,83,22,92,99
+63,55,61,92,87,64,88,85,72
+67,92,77,64,52,51,81,91,17,85,21,22,14,78,15,88,18,72,83,55,68
+36,78,92,22,51,87,99
+37,13,36,56,81,92,88,55,15
+29,35,37,13,48,33,23,25,56,96,89,17,81,21,83,24,52,22,92,99,88

+ 264 - 0
aoc2024/day6/README.md

@@ -0,0 +1,264 @@
+--- Day 6: Guard Gallivant ---
+------------------------------
+
+The Historians use their fancy [device](4) again, this time to whisk you all away to the North Pole prototype suit manufacturing lab... in the year [1518](/2018/day/5)! It turns out that having direct access to history is very convenient for a group of historians.
+
+
+You still have to be careful of time paradoxes, and so it will be important to avoid anyone from 1518 while The Historians search for the Chief. Unfortunately, a single *guard* is patrolling this part of the lab.
+
+
+Maybe you can work out where the guard will go ahead of time so that The Historians can search safely?
+
+
+You start by making a map (your puzzle input) of the situation. For example:
+
+
+
+```
+....#.....
+.........#
+..........
+..#.......
+.......#..
+..........
+.#..^.....
+........#.
+#.........
+......#...
+
+```
+
+The map shows the current position of the guard with `^` (to indicate the guard is currently facing *up* from the perspective of the map). Any *obstructions* - crates, desks, alchemical reactors, etc. - are shown as `#`.
+
+
+Lab guards in 1518 follow a very strict patrol protocol which involves repeatedly following these steps:
+
+
+* If there is something directly in front of you, turn right 90 degrees.
+* Otherwise, take a step forward.
+
+
+Following the above protocol, the guard moves up several times until she reaches an obstacle (in this case, a pile of failed suit prototypes):
+
+
+
+```
+....#.....
+....^....#
+..........
+..#.......
+.......#..
+..........
+.#........
+........#.
+#.........
+......#...
+
+```
+
+Because there is now an obstacle in front of the guard, she turns right before continuing straight in her new facing direction:
+
+
+
+```
+....#.....
+........>#
+..........
+..#.......
+.......#..
+..........
+.#........
+........#.
+#.........
+......#...
+
+```
+
+Reaching another obstacle (a spool of several *very* long polymers), she turns right again and continues downward:
+
+
+
+```
+....#.....
+.........#
+..........
+..#.......
+.......#..
+..........
+.#......v.
+........#.
+#.........
+......#...
+
+```
+
+This process continues for a while, but the guard eventually leaves the mapped area (after walking past a tank of universal solvent):
+
+
+
+```
+....#.....
+.........#
+..........
+..#.......
+.......#..
+..........
+.#........
+........#.
+#.........
+......#v..
+
+```
+
+By predicting the guard's route, you can determine which specific positions in the lab will be in the patrol path. *Including the guard's starting position*, the positions visited by the guard before leaving the area are marked with an `X`:
+
+
+
+```
+....#.....
+....XXXXX#
+....X...X.
+..#.X...X.
+..XXXXX#X.
+..X.X.X.X.
+.#XXXXXXX.
+.XXXXXXX#.
+#XXXXXXX..
+......#X..
+
+```
+
+In this example, the guard will visit `*41*` distinct positions on your map.
+
+
+Predict the path of the guard. *How many distinct positions will the guard visit before leaving the mapped area?*
+
+
+--- Part Two ---
+----------------
+
+While The Historians begin working around the guard's patrol route, you borrow their fancy device and step outside the lab. From the safety of a supply closet, you time travel through the last few months and [record](/2018/day/4) the nightly status of the lab's guard post on the walls of the closet.
+
+
+Returning after what seems like only a few seconds to The Historians, they explain that the guard's patrol area is simply too large for them to safely search the lab without getting caught.
+
+
+Fortunately, they are *pretty sure* that adding a single new obstruction *won't* cause a time paradox. They'd like to place the new obstruction in such a way that the guard will get *stuck in a loop*, making the rest of the lab safe to search.
+
+
+To have the lowest chance of creating a time paradox, The Historians would like to know *all* of the possible positions for such an obstruction. The new obstruction can't be placed at the guard's starting position - the guard is there right now and would notice.
+
+
+In the above example, there are only `*6*` different positions where a new obstruction would cause the guard to get stuck in a loop. The diagrams of these six situations use `O` to mark the new obstruction, `|` to show a position where the guard moves up/down, `-` to show a position where the guard moves left/right, and `+` to show a position where the guard moves both up/down and left/right.
+
+
+Option one, put a printing press next to the guard's starting position:
+
+
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+....|..#|.
+....|...|.
+.#.*O*^---+.
+........#.
+#.........
+......#...
+
+```
+
+Option two, put a stack of failed suit prototypes in the bottom right quadrant of the mapped area:
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+..+-+-+#|.
+..|.|.|.|.
+.#+-^-+-+.
+......*O*.#.
+#.........
+......#...
+
+```
+
+Option three, put a crate of chimney-squeeze prototype fabric next to the standing desk in the bottom right quadrant:
+
+
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+..+-+-+#|.
+..|.|.|.|.
+.#+-^-+-+.
+.+----+*O*#.
+#+----+...
+......#...
+
+```
+
+Option four, put an alchemical retroencabulator near the bottom left corner:
+
+
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+..+-+-+#|.
+..|.|.|.|.
+.#+-^-+-+.
+..|...|.#.
+#*O*+---+...
+......#...
+
+```
+
+Option five, put the alchemical retroencabulator a bit to the right instead:
+
+
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+..+-+-+#|.
+..|.|.|.|.
+.#+-^-+-+.
+....|.|.#.
+#..*O*+-+...
+......#...
+
+```
+
+Option six, put a tank of sovereign glue right next to the tank of universal solvent:
+
+
+
+```
+....#.....
+....+---+#
+....|...|.
+..#.|...|.
+..+-+-+#|.
+..|.|.|.|.
+.#+-^-+-+.
+.+----++#.
+#+----++..
+......#*O*..
+
+```
+
+It doesn't really matter what you choose to use as an obstacle so long as you and The Historians can put it into position without the guard noticing. The important thing is having enough options that you can find one that minimizes time paradoxes, and in this example, there are `*6*` different positions you could choose.
+
+
+You need to get the guard stuck in a loop by adding a single new obstruction. *How many different positions could you choose for this obstruction?*

+ 190 - 0
aoc2024/day6/day6.go

@@ -0,0 +1,190 @@
+package main
+
+import (
+	"bufio"
+	"flag"
+	"fmt"
+	"os"
+	"time"
+)
+
+func main() {
+	args := flag.Bool("example", false, "example or input")
+	flag.Parse()
+	filename := "input.txt"
+	if *args {
+		filename = "example.txt"
+	}
+	file, err := os.Open(filename)
+	if err != nil {
+		fmt.Println(err)
+		return
+	}
+	defer file.Close()
+
+	var grid []string
+	scanner := bufio.NewScanner(file)
+	for scanner.Scan() {
+		grid = append(grid, scanner.Text())
+	}
+
+	if err := scanner.Err(); err != nil {
+		fmt.Println(err)
+		return
+	}
+
+	startX, startY, direction := findStart(grid)
+
+	start := time.Now()
+	_, visited := simulate(grid, startX, startY, direction)
+	lenv := make(map[[2]int]bool)
+	for x := range visited {
+		lenv[[2]int{x[0], x[1]}] = true
+	}
+	part1_time := time.Since(start)
+	start = time.Now()
+	loopPositions := findLoopObstacles(grid, [3]int{startX, startY, directionIndex(direction)}, visited)
+	part2_time := time.Since(start)
+	fmt.Println("Visited Distinct Positions:", len(lenv), "in time:", part1_time)
+	fmt.Println("Loop Positions:", len(loopPositions), "in time:", part2_time)
+}
+
+func findStart(grid []string) (int, int, string) {
+	for y, row := range grid {
+		for x, cell := range row {
+			switch cell {
+			case '^':
+				return x, y, "up"
+			case '>':
+				return x, y, "right"
+			case '<':
+				return x, y, "left"
+			case 'v':
+				return x, y, "down"
+			}
+		}
+	}
+	return -1, -1, ""
+}
+
+func simulate(grid []string, startX, startY int, direction string) (bool, map[[3]int]bool) {
+	visited := make(map[[3]int]bool)
+	directions := map[string][2]int{
+		"up":    {0, -1},
+		"right": {1, 0},
+		"down":  {0, 1},
+		"left":  {-1, 0},
+	}
+	turnRight := map[string]string{
+		"up":    "right",
+		"right": "down",
+		"down":  "left",
+		"left":  "up",
+	}
+
+	x, y := startX, startY
+	visited[[3]int{x, y, directionIndex(direction)}] = true
+
+	for {
+		dx, dy := directions[direction][0], directions[direction][1]
+		nextX, nextY := x+dx, y+dy
+
+		if nextY < 0 || nextY >= len(grid) || nextX < 0 || nextX >= len(grid[nextY]) {
+			return false, visited
+		}
+
+		if grid[nextY][nextX] == '#' {
+			direction = turnRight[direction]
+		} else {
+			x, y = nextX, nextY
+		}
+
+		state := [3]int{x, y, directionIndex(direction)}
+		if visited[state] {
+			return true, visited
+		}
+		visited[state] = true
+	}
+
+}
+
+func findLoopObstacles(grid []string, start [3]int, visited map[[3]int]bool) map[[2]int]bool {
+
+	originalGrid := make([]string, len(grid))
+	copy(originalGrid, grid)
+
+	loopPositions := make(map[[2]int]bool)
+
+	for point := range visited {
+		x, y, _ := point[0], point[1], point[2]
+		if x == start[0] && y == start[1] {
+			continue
+		}
+
+		gridCopy := make([]string, len(originalGrid))
+		copy(gridCopy, originalGrid)
+		gridCopy[y] = replaceCharAt(gridCopy[y], x, '#')
+
+		cycle, _ := simulate(gridCopy,
+			// x-indexPairDirection(direction)[0],
+			// y-indexPairDirection(direction)[1],
+			// indexDirection(direction+1),
+			start[0],
+			start[1],
+			indexDirection(start[2]),
+		)
+		if cycle {
+			loopPositions[[2]int{x, y}] = true
+		}
+	}
+
+	return loopPositions
+}
+
+func replaceCharAt(s string, index int, newChar rune) string {
+	runes := []rune(s)
+	runes[index] = newChar
+	return string(runes)
+}
+
+func directionIndex(direction string) int {
+	switch direction {
+	case "up":
+		return 0
+	case "right":
+		return 1
+	case "down":
+		return 2
+	case "left":
+		return 3
+	}
+	return -1
+}
+
+func indexDirection(direction int) string {
+	switch direction % 4 {
+	case 0:
+		return "up"
+	case 1:
+		return "right"
+	case 2:
+		return "down"
+	case 3:
+		return "left"
+	}
+	return ""
+}
+
+func indexPairDirection(direction int) [2]int {
+	switch direction {
+	case 0:
+		return [2]int{0, -1}
+	case 1:
+		return [2]int{1, 0}
+	case 2:
+		return [2]int{0, 1}
+	case 3:
+		return [2]int{-1, 0}
+	}
+	return [2]int{0, 0}
+}

+ 0 - 0
aoc2024/day6/day6.py


+ 10 - 0
aoc2024/day6/example.txt

@@ -0,0 +1,10 @@
+....#.....
+.........#
+..........
+..#.......
+.......#..
+..........
+.#..^.....
+........#.
+#.........
+......#...

+ 130 - 0
aoc2024/day6/input.txt

@@ -0,0 +1,130 @@
+..#.........#...#......#...........#.#...#............#...#.........#....#......................#......#..........................
+...........#....#.............#.....................................#............................................#.....#..........
+.................#.........#.......#.......#..#............#.........#.........#............................................#.....
+......#................................#.........................................#................................................
+#...............................##......#.#...........................#....................#...#...............#.................#
+.............#......#...........................................#..............#..........#..............#........................
+...#...................#..............#........#.......#..........#.........................#.#.....#.....#.......................
+#.#...#.............................#.................................................#..............#............#...............
+.............................#.......#.............#......#...............#.....#.................................................
+....................................#.....................................#.................#........#..........#.#..#...........#
+......................#......#...............................#.................#.......#......................#.......#...........
+...#..............#....................#............#...........##..#.....................................................#.......
+....#.........#...................................#................................................#..........................#...
+..............#.....#.................................................................#..#.....##.......#.........................
+.........#....#...........##..........................................#......#.....................#..........#.......#...........
+..#....#..........#.................................................................#....#............#............#........#.....
+............#.#....#...........#.............#...........#..................#.....#.................................#.......#.....
+..........#.......#............................#........#...........#.......#...#....#........#.............##.#............#.....
+...................#.........#....#.....................................................................#.#..........#............
+.#...#.#..................#...............................................#...........................#......................#....
+.........#..............#.........#.......#.#......##..................#......#...#..#...........#.....................#..........
+...............................#.............#..#......#............#..........#......................#..........#.............#..
+..........#.....#..........................#..................................................#.#..#.....#........................
+............#..##.................................#....................#.....#.......................................#............
+......................#.#...................#......#..............................................................#...............
+.......#.............................................................................#............................................
+........#.................#....................................................#.......................................#....##.#..
+..................#........................#......#..##....#.........#...##..#....................................#...............
+.............#..............................................................................##...#......#.................#.......
+..................................#.#.............................................................................#...............
+...........#.................................#.......................................................................#......#.....
+.....#............................................................#................................................#..............
+.....#...........#.#..........#..............#..........................#.................................................#.......
+....#........#...#..........#..#..........................................................................#.......................
+.........................................................................#.....#.......................................#....#.....
+...............#...#..#.....#.......................#.................#........#..........##....................................#.
+.......................#....#...#..................#..................#.....................................#.............#.......
+...........#..#...#..............................................^........#........................#......................#.......
+.............................................#.................................................................................#..
+......#...#.........#.....................................#...............................................#..#....#.......#.......
+...#......................................................#.................#..#.............................................#....
+.....#......................#.......................................#.............................................#....#..........
+...#.....................................................#......#...#.......#....#..............................#....#............
+......#.....#.....#...........#...#................#...........................................#..................................
+...................................#...............#......................................................#.......................
+..............................#...#........................................................#.#.............#......................
+......#.......#............#..#......................#..#.....#..................#......#.........................................
+#......#....#.......#....................#.....#.#............................................................................#...
+.#....#...................................#.................#....................#........................................#.......
+............................................#...................................#.......#..............#.........................#
+............##.........#..............................................................................#.........#.................
+##.................................................#.......................#.#.....#..............................................
+...........................#..........#...#.#.........................#.................................##.....#..................
+.............#..........#........................................#............#............#.....................................#
+.....................................................#.................................................#..........................
+.....#........................................#.............................#...#.....................#...........................
+.......#..................................#...........#.......#.....#........................................#.......#............
+.............#.......................#......................#.....#.......#..................................#..#........#........
+.......................................................#......#...............#.........#.............#............#..............
+....#...............................#.#.....................#.................................................................#..#
+...........................#........#..........................................#........................................#.........
+....#.............................................................................................................................
+.##........#.......#..................#.#....#.............................................................#.##...................
+.#..#.......................##........................................................#...............................#...........
+.....#.#..............#...........................................#...............................................................
+.....#.#............................#.............................................................................................
+......................#............................#....#............................................................#............
+.......#.......................................................................#..................#...##..........................
+...............#...................................................#.....................................#...............#.#......
+....#..........#.......#..#................................#......................................................................
+#......##..................................................................#...#........................#.........................
+..................................#........................................................................#...........#......#...
+.#....................#....#..................................#..#..................#.#.......................#...................
+......#..#................................................................................................##......................
+.....##........#..#.......................#.........#............#....#...........................................................
+...............#...........#.................#...........#.........#.......................#.........#........................#...
+............................................................................................#..#..................................
+..........................................#.............#..#...............#.............................#.#......#.............#.
+......................#............#..........#............................................................#...#................#.
+...........#...................#..................................................................................................
+.......#........................#.................................................................#.................#.............
+#...##................#......................................................................#................................#...
+...#.....#.......................#...#..............#....................#.........#.........#....................................
+....#.....................................#.............................................................................#.........
+.........#..............................................................................#..............#..........................
+...................................#.#...............#........................................................................##..
+.........#............#..............#..........................................................................#...#.............
+.....#.......................#..#....#.#....................#..........................................#..........................
+.......................................#........#.........#.....................#.............#...........#...............#.......
+................#.................................................................................................................
+.......#....................................#..................#...........#.....#.........................#......................
+...................#................................................................#...............#................#............
+..........#.......................#......................#...........#..#........#....#.........................#.................
+...................#........................#.......#................................................#............................
+.......................#......................................................#...........#.......#...................#...........
+........#..........#........#......#......................#......................................#...............#................
+...........................................................#...#..................................................................
+.......................#......................#............#..#....#...#............................#.............................
+.#.#...............#..........#..........##........#..............................................................................
+##.........#....................#...................#.........#......................##..................#...............#........
+.#......................#...#...#......................#............#......................#.................#..................#.
+#..............................#......................................#.........#.#...............................................
+...........#....#......#.......#..........................#..........................................#......#............#..#.....
+................................................................................................#.......#.........................
+....#..................................#..........................#.................................#...#...#.....................
+.......................#.#..#.............................#.#...........................#......#..........#.......................
+...##.......................................#..................#....................#.............................................
+...#.......#........................#..........##.....#............#......................#.....................................#.
+......#..............#.............................#.............................................#.............................#..
+#...........................................#.......#....#.#..........#........#............#.......................#.......#.....
+..................#.......#............#.....#.............................................................#......................
+.#.....................................................................................#...................................#......
+...........#.........#.#.................#..........................#............................................#.......##.......
+.......................#......#.................................................#........................#.................#......
+..................#........................................................#................................................#....#
+...............................#.......#....#.........#..........#.....#.......................................#..#...............
+......##................##...#....#...#...#............................................................................#..........
+.......................#............#...................................#....#.......#.............................#..............
+..............................#.........................................................#........#.............#..................
+........................#............................................#..................#.....#...................#...............
+............#......#...............................#.............................................................................#
+.#.........#.........#.........#.......#.#..#...#...............................#.......#.........#..........................#....
+........................#.................................................#....................................##......#..........
+....#.......#.....................##...#..........................................................................................
+.................................#.......................................#.......................#.#......#.......................
+.#.............#..................#...........................#.................#...........................................#.....
+.....#.........#................#..........#..#..........#......................#...#......................#....#.................
+.................#......#.....................................................................#...................................
+......................#.......................................................#..#......#..............#..#..#..........#.........
+...............................#.........#........#..................#.#.........#.#.#........#..#.........#....##...#............

+ 2 - 0
aoc2024/go.mod

@@ -1,3 +1,5 @@
 module aoc2024
 
 go 1.23.3
+
+require github.com/elliotchance/orderedmap/v3 v3.0.0

+ 10 - 0
aoc2024/go.sum

@@ -0,0 +1,10 @@
+github.com/davecgh/go-spew v1.1.0 h1:ZDRjVQ15GmhC3fiQ8ni8+OwkZQO4DARzQgrnXU1Liz8=
+github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/elliotchance/orderedmap/v3 v3.0.0 h1:Yay/tDjX+vzza+Drcoo8VEbuBnOYGpgenCXWcpQSFDg=
+github.com/elliotchance/orderedmap/v3 v3.0.0/go.mod h1:G+Hc2RwaZvJMcS4JpGCOyViCnGeKf0bTYCGTO4uhjSo=
+github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/stretchr/testify v1.7.1 h1:5TQK59W5E3v0r2duFAb7P95B6hEeOyEnHRa8MjYSMTY=
+github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
+gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
+gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=