2016-12-09 15:59:13 +00:00
|
|
|
|
Advent of Code
|
|
|
|
|
|
|
|
|
|
--- Day 9: Explosives in Cyberspace ---
|
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
Wandering around a secure area, you come across a datalink port to a new
|
|
|
|
|
part of the network. After briefly scanning it for interesting files, you
|
|
|
|
|
find one file in particular that catches your attention. It's compressed
|
|
|
|
|
with an experimental format, but fortunately, the documentation for the
|
|
|
|
|
format is nearby.
|
|
|
|
|
|
|
|
|
|
The format compresses a sequence of characters. Whitespace is ignored. To
|
|
|
|
|
indicate that some sequence should be repeated, a marker is added to the
|
|
|
|
|
file, like (10x2). To decompress this marker, take the subsequent 10
|
|
|
|
|
characters and repeat them 2 times. Then, continue reading the file after
|
|
|
|
|
the repeated data. The marker itself is not included in the decompressed
|
|
|
|
|
output.
|
|
|
|
|
|
|
|
|
|
If parentheses or other characters appear within the data referenced by a
|
|
|
|
|
marker, that's okay - treat it like normal data, not a marker, and then
|
|
|
|
|
resume looking for markers after the decompressed section.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
For example:
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
• ADVENT contains no markers and decompresses to itself with no changes,
|
|
|
|
|
resulting in a decompressed length of 6.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
• A(1x5)BC repeats only the B a total of 5 times, becoming ABBBBBC for a
|
|
|
|
|
decompressed length of 7.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
|
|
|
|
• (3x3)XYZ becomes XYZXYZXYZ for a decompressed length of 9.
|
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
• A(2x2)BCD(2x2)EFG doubles the BC and EF, becoming ABCBCDEFEFG for a
|
|
|
|
|
decompressed length of 11.
|
|
|
|
|
|
|
|
|
|
• (6x1)(1x3)A simply becomes (1x3)A - the (1x3) looks like a marker, but
|
|
|
|
|
because it's within a data section of another marker, it is not treated
|
|
|
|
|
any differently from the A that comes after it. It has a decompressed
|
|
|
|
|
length of 6.
|
|
|
|
|
|
|
|
|
|
• X(8x2)(3x3)ABCY becomes X(3x3)ABC(3x3)ABCY (for a decompressed length of
|
|
|
|
|
18), because the decompressed data from the (8x2) marker (the (3x3)ABC) is
|
|
|
|
|
skipped and not processed further.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
What is the decompressed length of the file (your puzzle input)? Don't count
|
|
|
|
|
whitespace.
|
|
|
|
|
|
|
|
|
|
Your puzzle answer was 110346.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
|
|
|
|
--- Part Two ---
|
|
|
|
|
|
|
|
|
|
Apparently, the file actually uses version two of the format.
|
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
In version two, the only difference is that markers within decompressed data
|
|
|
|
|
are decompressed. This, the documentation explains, provides much more
|
|
|
|
|
substantial compression capabilities, allowing many-gigabyte files to be
|
|
|
|
|
stored in only a few kilobytes.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
• (3x3)XYZ still becomes XYZXYZXYZ, as the decompressed section contains
|
|
|
|
|
no markers.
|
|
|
|
|
|
|
|
|
|
• X(8x2)(3x3)ABCY becomes XABCABCABCABCABCABCY, because the decompressed
|
|
|
|
|
data from the (8x2) marker is then further decompressed, thus triggering
|
|
|
|
|
the (3x3) marker twice for a total of six ABC sequences.
|
|
|
|
|
|
|
|
|
|
• (27x12)(20x12)(13x14)(7x10)(1x12)A decompresses into a string of A
|
|
|
|
|
repeated 241920 times.
|
|
|
|
|
|
|
|
|
|
• (25x3)(3x3)ABC(2x3)XY(5x2)PQRSTX(18x9)(3x2)TWO(5x7)SEVEN becomes 445
|
|
|
|
|
characters long.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
Unfortunately, the computer you brought probably doesn't have enough memory
|
|
|
|
|
to actually decompress the file; you'll have to come up with another way to
|
|
|
|
|
get its decompressed length.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
|
|
|
|
What is the decompressed length of the file using this improved format?
|
|
|
|
|
|
|
|
|
|
Although it hasn't changed, you can still get your puzzle input.
|
|
|
|
|
|
2018-03-15 16:24:23 +00:00
|
|
|
|
Your puzzle answer was 10774309173.
|
2016-12-09 15:59:13 +00:00
|
|
|
|
|
|
|
|
|
References
|
|
|
|
|
|
|
|
|
|
Visible links
|
|
|
|
|
. http://adventofcode.com/
|
|
|
|
|
. http://adventofcode.com/2016/about
|
|
|
|
|
. http://adventofcode.com/2016/support
|
|
|
|
|
. http://adventofcode.com/2016/events
|
|
|
|
|
. http://adventofcode.com/2016/settings
|
|
|
|
|
. http://adventofcode.com/2016/auth/logout
|
|
|
|
|
. http://adventofcode.com/2016
|
|
|
|
|
. http://adventofcode.com/2016
|
|
|
|
|
. http://adventofcode.com/2016/leaderboard
|
|
|
|
|
. http://adventofcode.com/2016/stats
|
|
|
|
|
. http://adventofcode.com/2016/sponsors
|
|
|
|
|
. http://adventofcode.com/2016/sponsors
|
|
|
|
|
. http://adventofcode.com/2016/day/9/input
|