--- Day 15: Lens Library ---
The newly-focused parabolic reflector dish is sending all of the collected light to a point on the side of yet another mountain - the largest mountain on Lava Island. As you approach the mountain, you find that the light is being collected by the wall of a large facility embedded in the mountainside.
You find a door under a large sign that says "Lava Production Facility" and next to a smaller sign that says "Danger - Personal Protective Equipment required beyond this point".
As you step inside, you are immediately greeted by a somewhat panicked reindeer wearing goggles and a loose-fitting hard hat. The reindeer leads you to a shelf of goggles and hard hats (you quickly find some that fit) and then further into the facility. At one point, you pass a button with a faint snout mark and the label "PUSH FOR HELP". No wonder you were loaded into that trebuchet so quickly!
You pass through a final set of doors surrounded with even more warning signs and into what must be the room that collects all of the light from outside. As you admire the large assortment of lenses available to further focus the light, the reindeer brings you a book titled "Initialization Manual".
"Hello!", the book cheerfully begins, apparently unaware of the concerned reindeer reading over your shoulder. "This procedure will let you bring the Lava Production Facility online - all without burning or melting anything unintended!"
"Before you begin, please be prepared to use the Holiday ASCII String Helper algorithm (appendix 1A)." You turn to appendix 1A. The reindeer leans closer with interest.
The HASH algorithm is a way to turn any string of characters into a single number in the range 0 to 255. To run the HASH algorithm on a string, start with a current value of 0
. Then, for each character in the string starting from the beginning:
- Determine the ASCII code for the current character of the string.
- Increase the current value by the ASCII code you just determined.
- Set the current value to itself multiplied by
17
. - Set the current value to the remainder of dividing itself by
256
.
After following these steps for each character in the string in order, the current value is the output of the HASH algorithm.
So, to find the result of running the HASH algorithm on the string HASH
:
- The current value starts at
0
. - The first character is
H
; its ASCII code is72
. - The current value increases to
72
. - The current value is multiplied by
17
to become1224
. - The current value becomes
200
(the remainder of1224
divided by256
). - The next character is
A
; its ASCII code is65
. - The current value increases to
265
. - The current value is multiplied by
17
to become4505
. - The current value becomes
153
(the remainder of4505
divided by256
). - The next character is
S
; its ASCII code is83
. - The current value increases to
236
. - The current value is multiplied by
17
to become4012
. - The current value becomes
172
(the remainder of4012
divided by256
). - The next character is
H
; its ASCII code is72
. - The current value increases to
244
. - The current value is multiplied by
17
to become4148
. - The current value becomes
52
(the remainder of4148
divided by256
).
So, the result of running the HASH algorithm on the string HASH
is 52
.
The initialization sequence (your puzzle input) is a comma-separated list of steps to start the Lava Production Facility. Ignore newline characters when parsing the initialization sequence. To verify that your HASH algorithm is working, the book offers the sum of the result of running the HASH algorithm on each step in the initialization sequence.
For example:
rn=1,cm-,qp=3,cm=2,qp-,pc=4,ot=9,ab=5,pc-,pc=6,ot=7
This initialization sequence specifies 11 individual steps; the result of running the HASH algorithm on each of the steps is as follows:
rn=1
becomes30
.cm-
becomes253
.qp=3
becomes97
.cm=2
becomes47
.qp-
becomes14
.pc=4
becomes180
.ot=9
becomes9
.ab=5
becomes197
.pc-
becomes48
.pc=6
becomes214
.ot=7
becomes231
.
In this example, the sum of these results is 1320
. Unfortunately, the reindeer has stolen the page containing the expected verification number and is currently running around the facility with it excitedly.
Run the HASH algorithm on each step in the initialization sequence. What is the sum of the results? (The initialization sequence is one long line; be careful when copy-pasting it.)