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");
|
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<()> {
|
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(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue