Day 10, parts 1 + 2!
This commit is contained in:
parent
441e71e4f6
commit
3653930b22
3 changed files with 268 additions and 1 deletions
146
2022/Data/day10-input-longer-example.txt
Normal file
146
2022/Data/day10-input-longer-example.txt
Normal file
|
@ -0,0 +1,146 @@
|
|||
addx 15
|
||||
addx -11
|
||||
addx 6
|
||||
addx -3
|
||||
addx 5
|
||||
addx -1
|
||||
addx -8
|
||||
addx 13
|
||||
addx 4
|
||||
noop
|
||||
addx -1
|
||||
addx 5
|
||||
addx -1
|
||||
addx 5
|
||||
addx -1
|
||||
addx 5
|
||||
addx -1
|
||||
addx 5
|
||||
addx -1
|
||||
addx -35
|
||||
addx 1
|
||||
addx 24
|
||||
addx -19
|
||||
addx 1
|
||||
addx 16
|
||||
addx -11
|
||||
noop
|
||||
noop
|
||||
addx 21
|
||||
addx -15
|
||||
noop
|
||||
noop
|
||||
addx -3
|
||||
addx 9
|
||||
addx 1
|
||||
addx -3
|
||||
addx 8
|
||||
addx 1
|
||||
addx 5
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx -36
|
||||
noop
|
||||
addx 1
|
||||
addx 7
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx 2
|
||||
addx 6
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx 1
|
||||
noop
|
||||
noop
|
||||
addx 7
|
||||
addx 1
|
||||
noop
|
||||
addx -13
|
||||
addx 13
|
||||
addx 7
|
||||
noop
|
||||
addx 1
|
||||
addx -33
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx 2
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx 8
|
||||
noop
|
||||
addx -1
|
||||
addx 2
|
||||
addx 1
|
||||
noop
|
||||
addx 17
|
||||
addx -9
|
||||
addx 1
|
||||
addx 1
|
||||
addx -3
|
||||
addx 11
|
||||
noop
|
||||
noop
|
||||
addx 1
|
||||
noop
|
||||
addx 1
|
||||
noop
|
||||
noop
|
||||
addx -13
|
||||
addx -19
|
||||
addx 1
|
||||
addx 3
|
||||
addx 26
|
||||
addx -30
|
||||
addx 12
|
||||
addx -1
|
||||
addx 3
|
||||
addx 1
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx -9
|
||||
addx 18
|
||||
addx 1
|
||||
addx 2
|
||||
noop
|
||||
noop
|
||||
addx 9
|
||||
noop
|
||||
noop
|
||||
noop
|
||||
addx -1
|
||||
addx 2
|
||||
addx -37
|
||||
addx 1
|
||||
addx 3
|
||||
noop
|
||||
addx 15
|
||||
addx -21
|
||||
addx 22
|
||||
addx -6
|
||||
addx 1
|
||||
noop
|
||||
addx 2
|
||||
addx 1
|
||||
noop
|
||||
addx -10
|
||||
noop
|
||||
noop
|
||||
addx 20
|
||||
addx 1
|
||||
addx 2
|
||||
addx 2
|
||||
addx -6
|
||||
addx -11
|
||||
noop
|
||||
noop
|
||||
noop
|
3
2022/Data/day10-input-small-example.txt
Normal file
3
2022/Data/day10-input-small-example.txt
Normal file
|
@ -0,0 +1,3 @@
|
|||
noop
|
||||
addx 3
|
||||
addx -5
|
|
@ -1,6 +1,124 @@
|
|||
|
||||
const INPUT: &'static str = include_str!("../../Data/day10-input.txt");
|
||||
|
||||
#[derive(Debug)]
|
||||
enum Instruction {
|
||||
Noop,
|
||||
AddX(i32),
|
||||
}
|
||||
|
||||
impl Instruction {
|
||||
fn number_of_cycles(&self) -> u32 {
|
||||
match self {
|
||||
Instruction::Noop => 1,
|
||||
Instruction::AddX(_) => 2,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
struct CPU<'a> {
|
||||
instructions: Box<dyn Iterator<Item = Instruction> + 'a>,
|
||||
current_instruction: Option<Instruction>,
|
||||
cycle: u32,
|
||||
x: i32,
|
||||
}
|
||||
|
||||
impl<'a> CPU<'a> {
|
||||
fn new<T: Iterator<Item = Instruction> + 'a>(instructions: T) -> CPU<'a> {
|
||||
CPU {
|
||||
instructions: Box::new(instructions),
|
||||
current_instruction: None,
|
||||
cycle: 0,
|
||||
x: 1,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Iterator for CPU<'_> {
|
||||
type Item = State;
|
||||
|
||||
fn next(&mut self) -> Option<Self::Item> {
|
||||
if self.current_instruction.is_none() {
|
||||
self.current_instruction = self.instructions.next();
|
||||
self.cycle = 0;
|
||||
}
|
||||
|
||||
if let Some(current_instruction) = &self.current_instruction {
|
||||
let state = Some(State::from_cpu(&self));
|
||||
self.cycle += 1;
|
||||
|
||||
if self.cycle >= current_instruction.number_of_cycles() {
|
||||
match current_instruction {
|
||||
Instruction::Noop => {}
|
||||
Instruction::AddX(value) => {
|
||||
self.x += value;
|
||||
}
|
||||
}
|
||||
|
||||
self.current_instruction = self.instructions.next();
|
||||
self.cycle = 0;
|
||||
}
|
||||
|
||||
state
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
struct State {
|
||||
x: i32,
|
||||
}
|
||||
|
||||
impl State {
|
||||
fn from_cpu(cpu: &CPU) -> State {
|
||||
State { x: cpu.x }
|
||||
}
|
||||
}
|
||||
|
||||
pub fn main(_filename: &str) -> std::io::Result<()> {
|
||||
let cpu = CPU::new(INPUT.lines().map(|line| -> Instruction {
|
||||
if line.starts_with("addx") {
|
||||
let value = i32::from_str_radix(line.split(" ").collect::<Vec<&str>>()[1], 10).unwrap();
|
||||
Instruction::AddX(value)
|
||||
} else {
|
||||
Instruction::Noop
|
||||
}
|
||||
}));
|
||||
|
||||
let mut number_of_cycles = 0;
|
||||
let mut signal_strengths = 0;
|
||||
let mut cycles: Vec<State> = vec![];
|
||||
|
||||
for (i, cycle) in cpu.enumerate() {
|
||||
cycles.push(cycle.clone());
|
||||
|
||||
let x = cycle.x;
|
||||
|
||||
let cycle_number = i as i32 + 1;
|
||||
if cycle_number % 40 == 20 {
|
||||
signal_strengths += x * cycle_number;
|
||||
}
|
||||
number_of_cycles = i;
|
||||
|
||||
let i = i as i32;
|
||||
if i > 0 && i % 40 == 0 {
|
||||
println!("");
|
||||
}
|
||||
let horizontal_beam_position = i % 40;
|
||||
if horizontal_beam_position == (x - 1)
|
||||
|| horizontal_beam_position == x
|
||||
|| horizontal_beam_position == (x + 1)
|
||||
{
|
||||
print!("#");
|
||||
} else {
|
||||
print!(".");
|
||||
}
|
||||
}
|
||||
|
||||
println!("");
|
||||
println!("There were {} instructions", number_of_cycles + 1);
|
||||
println!("Part 1: sum of signal strengths: {}", signal_strengths);
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue