From 3ce503b8cea9dd70c73fb6c77de3f25c81fd1e3f Mon Sep 17 00:00:00 2001 From: login000 Date: Thu, 12 Dec 2024 02:10:37 +1030 Subject: [PATCH] Day 8. Set enableResonantHarmonics to true for part 2 --- Advent24/Day8.cs | 104 +++++++++++++++++++++++++++++++++++++++ Advent24/Program.cs | 3 +- Advent24/inputd8.txt | 50 +++++++++++++++++++ Advent24/inputd8test.txt | 12 +++++ 4 files changed, 168 insertions(+), 1 deletion(-) create mode 100644 Advent24/Day8.cs create mode 100644 Advent24/inputd8.txt create mode 100644 Advent24/inputd8test.txt diff --git a/Advent24/Day8.cs b/Advent24/Day8.cs new file mode 100644 index 0000000..f93c60c --- /dev/null +++ b/Advent24/Day8.cs @@ -0,0 +1,104 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Reflection.Emit; +using System.Text; +using System.Threading.Tasks; +using System.Text.RegularExpressions; + +namespace Advent24 +{ + internal class Day8 + { + public Day8() + { + String fileData = System.IO.File.ReadAllText(@"..\..\..\inputd8.txt"); + + // set this to false for part 1 + Boolean enableResonantHarmonics = true; + + // get width of line to be able to navigate the map block in + // both dimensions + Int32 mapWidth = fileData.IndexOf('\n'); + Int32 mapWidthIncludingNewline = mapWidth + 1; + String pattern = @"[A-Za-z0-9]"; + + Regex r = new(pattern, RegexOptions.Multiline, TimeSpan.FromMilliseconds(150)); + + Match m = r.Match(fileData); + + // list of linear-integer locations of antennas indexed by antenna type (a single alphanumeric character) + Dictionary> antennaLocationsMap = []; + + while (m.Success) + { + if (!antennaLocationsMap.TryGetValue(m.Groups[0].Value[0], out List? antennaLocations)) + antennaLocationsMap.Add(m.Groups[0].Value[0], [m.Groups[0].Index]); + else + antennaLocationsMap[m.Groups[0].Value[0]].Add(m.Groups[0].Index); + + // Console.WriteLine("antennaLocationsMap[{0:d}] = {1:d}", m.Groups[0].Value[0], antennaLocationsMap[m.Groups[0].Value[0]].Last()); + + m = m.NextMatch(); + } + + // set of linear-integer locations of antinodes indexed by antenna type (single-character alphanumeric) + Dictionary> antinodeLocationsMap = []; + + // set of linear-integer locations of antinodes overall + HashSet overallAntinodeLocations = []; + + foreach (Char antennaType in antennaLocationsMap.Keys) + { + if (!antinodeLocationsMap.TryGetValue(antennaType, out HashSet? antinodeLocations)) + antinodeLocationsMap.Add(antennaType, []); + + // for each (ordered) pair of antennaLocations of the same antenna type, we'll construct an antinode + // and then add it to the antinodeLocationsMap (keyed by antenna type) + foreach(Int32 antennaLocation1 in antennaLocationsMap[antennaType]) + foreach(Int32 antennaLocation2 in antennaLocationsMap[antennaType]) + { + if (antennaLocation1 == antennaLocation2) + continue; + + Int32 antennaLocationDifference = antennaLocation2 - antennaLocation1; + Int32 antennaLocationXDifference = (antennaLocation2 % mapWidthIncludingNewline) - (antennaLocation1 % mapWidthIncludingNewline); + Int32 antinodeLocation = antennaLocation2; + do + { + Int32 antinodePreviousLocationX = antinodeLocation % mapWidthIncludingNewline; + antinodeLocation += antennaLocationDifference; + Int32 antinodeLocationXDifference = (antinodeLocation % mapWidthIncludingNewline) - antinodePreviousLocationX; + + // bounds checking + if ( + antinodeLocation < 0 || + antinodeLocation >= fileData.Length || + fileData[antinodeLocation] == '\n' || + // x-direction having changed implies we crossed the right/left boundary + ((antennaLocationXDifference > 0) != (antinodeLocationXDifference > 0)) + ) + break; + + antinodeLocationsMap[antennaType].Add(antinodeLocation); + } while (enableResonantHarmonics); + + if(enableResonantHarmonics) + { + antinodeLocationsMap[antennaType].Add(antennaLocation1); + antinodeLocationsMap[antennaType].Add(antennaLocation2); + } + } + + // adding to the overall antinode location set + overallAntinodeLocations = [.. overallAntinodeLocations, .. antinodeLocationsMap[antennaType]]; + } + + Int32 numberOfUniqueAntinodeLocations = overallAntinodeLocations.Count; + Console.WriteLine("numberOfUniqueAntinodeLocations = {0:d}", numberOfUniqueAntinodeLocations); + + // to keep the console window from closing + Console.ReadKey(); + } + } +} diff --git a/Advent24/Program.cs b/Advent24/Program.cs index 521c5c3..602f54e 100644 --- a/Advent24/Program.cs +++ b/Advent24/Program.cs @@ -13,7 +13,8 @@ namespace Advent24 //_ = new Day4(); //_ = new Day5(); //_ = new Day6(); - _ = new Day7(); + //_ = new Day7(); + _ = new Day8(); } } } diff --git a/Advent24/inputd8.txt b/Advent24/inputd8.txt new file mode 100644 index 0000000..e99bc0a --- /dev/null +++ b/Advent24/inputd8.txt @@ -0,0 +1,50 @@ +.....................U.........w.................. +l................................................. +...........o.a................U...w............... +............................................W..... +..........T....................s.............7.... +.............................................W.... +.........T..............4....n.d.H.........5...... +......T.....oj...U.....n...w......H...........z... +.G..x..........................E.....V..H......... +.........a....................d....s.......7w..... +...j....r.............o.............V.......d...W. +.......r..J.Goa.U...............n................z +.........Jj.........M..........Pv................. +...J...........t..3..M..............sLV........... +...................t................n............. +....r...........X...........M........v............ +...x....t......I......a.PM...............W........ +...........1.Bj....I........vO.h.dL............... +.........6....Rr......B...X........h..5v.L..z..... +......1G...........x.....3B.......5............... +.................B....0..........4..E............. +.....................X.....5..h....P....f.....D... +.......1........J.....eK.......................... +..................I....R....K...........k......... +......G..................O........................ +...........H...9...............K8.P.4..k..E....... +............1....3.............8.F.............f.. +.........................4........................ +.l...........X............9....................... +....N.................R...t.e..................... +...g............3..R.........e....h.........f..... +...........................e......i............... +................2...I.7..9..O.....s.........k..... +....................6...9E.............F..O....... +........................KN........................ +.......g......................Z.........F..f...Y.. +...........................A....i................. +...........6g...b........8.......y.....S.......... +..l.....6.....m...............8................... +....u..m...b...............p...A.................. +..............b.p........................k........ +....m......2...........Z..y....i.................. +........g2.....b.........i....D..ZF............... +......2.0...........p............N..........A..... +...m.............S...y........A...Z...N........... +..S..l..........................................Y. +........S....0u.................y......DY......... +...........0.........................D............ +.................u...................p...Y........ +.......u.......................................... diff --git a/Advent24/inputd8test.txt b/Advent24/inputd8test.txt new file mode 100644 index 0000000..de0f909 --- /dev/null +++ b/Advent24/inputd8test.txt @@ -0,0 +1,12 @@ +............ +........0... +.....0...... +.......0.... +....0....... +......A..... +............ +............ +........A... +.........A.. +............ +............ \ No newline at end of file