Skip to content

Latest commit

 

History

History
89 lines (67 loc) · 2.76 KB

day07.md

File metadata and controls

89 lines (67 loc) · 2.76 KB

Day 7: Some Assembly Required

Approach and Reflections

This one was a bit harder than your average early advent of code problem. We're given a list of logic gates operating on registers, and initial values for those registers, but everything is out of order. We have to find the final values on a certain register (or "wire").

Here, I put all of the gates in a list and repeatedly iterated over the entire list, searching for any gate that had two input values specified, but no output determined yet. This is not the most efficient - perhaps a topological sort would have been better - but it was sufficient and, YAGNI.

Also, my Python "Gate" dataclass is a little too complex: Calls to the constructor are quite ugly.

Solutions

Problem Description

2015 Day 07 on AdventOfCode.com

Part One

This year, Santa brought little Bobby Tables a set of wires and bitwise logic gates! Unfortunately, little Bobby is a little under the recommended age range, and he needs help assembling the circuit.

Each wire has an identifier (some lowercase letters) and can carry a 16-bit signal (a number from 0 to 65535). A signal is provided to each wire by a gate, another wire, or some specific value. Each wire can only get a signal from one source, but can provide its signal to multiple destinations. A gate provides no signal until all of its inputs have a signal.

The included instructions booklet describes how to connect the parts together: x AND y -> z means to connect wires x and y to an AND gate, and then connect its output to wire z.

For example:

    123 -> x means that the signal 123 is provided to wire x.
    x AND y -> z means that the bitwise AND of wire x and wire y is provided to wire z.
    p LSHIFT 2 -> q means that the value from wire p is left-shifted by 2 and then provided to wire q.
    NOT e -> f means that the bitwise complement of the value from wire e is provided to wire f.

Other possible gates include OR (bitwise OR) and RSHIFT (right-shift). If, for some reason, you'd like to emulate the circuit instead, almost all programming languages (for example, C, JavaScript, or Python) provide operators for these gates.

For example, here is a simple circuit:

123 -> x
456 -> y
x AND y -> d
x OR y -> e
x LSHIFT 2 -> f
y RSHIFT 2 -> g
NOT x -> h
NOT y -> i

After it is run, these are the signals on the wires:

d: 72
e: 507
f: 492
g: 114
h: 65412
i: 65079
x: 123
y: 456

In little Bobby's kit's instructions booklet (provided as your puzzle input), what signal is ultimately provided to wire a?

Part Two

Now, take the signal you got on wire a, override wire b to that signal, and reset the other wires (including wire a). What new signal is ultimately provided to wire a?