diff --git a/AdventOfCode/Day19.cs b/AdventOfCode/Day19.cs index 4049488..8146023 100644 --- a/AdventOfCode/Day19.cs +++ b/AdventOfCode/Day19.cs @@ -5,6 +5,8 @@ public class Day19 : BaseDay string[] _towels; string[] _patterns; + Dictionary> _towelsByFirstLetter = new Dictionary>(); + public Day19() { string[] lines = File.ReadAllLines(InputFilePath); @@ -15,6 +17,14 @@ public Day19() { _patterns[i-2] = lines[i].Trim(); } + + foreach (string towel in _towels) + { + if (!_towelsByFirstLetter.TryAdd(towel[0], new List { towel })) + { + _towelsByFirstLetter[towel[0]].Add(towel); + } + } } public override ValueTask Solve_1() @@ -26,7 +36,11 @@ public override ValueTask Solve_1() public override ValueTask Solve_2() { - return new("test"); + int result = _patterns.Sum(p => CountPatterns(p, 0)); + + //int result = CountPatterns(_patterns[0], 0); + + return new(result.ToString()); } private bool IsPatternPossible(string pattern, int position) @@ -58,4 +72,38 @@ private bool IsPatternPossible(string pattern, int position) return false; } + + private int CountPatterns(string pattern, int position) + { + if (position == pattern.Length) + { + return 1; + } + + int res = 0; + if (_towelsByFirstLetter.TryGetValue(pattern[position], out var towelsToCheck)) + { + foreach (string towel in towelsToCheck) + { + if (towel.Length <= pattern.Length - position) + { + bool matches = true; + for (int i = 0; i < towel.Length; ++i) + { + if (pattern[position + i] != towel[i]) + { + matches = false; + break; + } + } + if (matches) + { + res += CountPatterns(pattern, position + towel.Length); + } + } + } + } + + return res; + } }