Rudolph the Red-Nosed Reindeer is sick! His nose isn't shining very brightly, and he needs medicine.
Red-Nosed Reindeer biology isn't similar to regular reindeer biology; Rudolph is going to need custom-made medicine. Unfortunately, Red-Nosed Reindeer chemistry isn't similar to regular reindeer chemistry, either.
The North Pole is equipped with a Red-Nosed Reindeer nuclear fusion/fission plant, capable of constructing any Red-Nosed Reindeer molecule you need. It works by starting with some input molecule and then doing a series of replacements, one per step, until it has the right molecule.
However, the machine has to be calibrated before it can be used. Calibration involves determining the number of molecules that can be generated in one step from a given starting point.
For example, imagine a simpler machine that supports only the following replacements:
H => HO
H => OH
O => HH
Given the replacements above and starting with HOH
, the following molecules could be generated:
HOOH
(viaH => HO
on the firstH
).HOHO
(viaH => HO
on the secondH
).OHOH
(viaH => OH
on the firstH
).HOOH
(viaH => OH
on the secondH
).HHHH
(viaO => HH
).
So, in the example above, there are 4
distinct molecules (not five, because HOOH
appears twice) after one replacement from HOH
. Santa's favorite molecule, HOHOHO
, can become 7
distinct molecules (over nine replacements: six from H
, and three from O
).
The machine replaces without regard for the surrounding characters. For example, given the string H2O
, the transition H => OO
would result in OO2O
.
Your puzzle input describes all of the possible replacements and, at the bottom, the medicine molecule for which you need to calibrate the machine. How many distinct molecules can be created after all the different ways you can do one replacement on the medicine molecule?
Your puzzle answer was 518
.
Now that the machine is calibrated, you're ready to begin molecule fabrication.
Molecule fabrication always begins with just a single electron, e
, and applying replacements one at a time, just like the ones during calibration.
For example, suppose you have the following replacements:
e => H
e => O
H => HO
H => OH
O => HH
If you'd like to make HOH
, you start with e
, and then make the following replacements:
e => O
to getO
O => HH
to getHH
H => OH
(on the secondH
) to getHOH
So, you could make HOH
after 3
steps. Santa's favorite molecule, HOHOHO
, can be made in 6
steps.
How long will it take to make the medicine? Given the available replacements and the medicine molecule in your puzzle input, what is the fewest number of steps to go from e
to the medicine molecule?
Your puzzle answer was 200
.
The second part has the potential to be a major headache, and indeed a standard BFS approach blows up quite spectacularly. So imagine my surprise when I found out that even the dumbest DFS implementation works just fine! I actually added a greedy optimization later on to be a bit on the safe side in case my input was too optimistic, but there seems to be only a single input to begin with: I found the exact same input file in other people's repositories ...
- Part 1, Python: 275 bytes, <100 ms
- Part 2, Python (dumb DFS): 240 bytes, <100 ms
- Part 2, Python (greedy DFS): 281 bytes, <100 ms