diff --git a/input/input05.txt b/input/input05.txt deleted file mode 100644 index d89c0ae..0000000 --- a/input/input05.txt +++ /dev/null @@ -1 +0,0 @@ -3,225,1,225,6,6,1100,1,238,225,104,0,1102,68,5,225,1101,71,12,225,1,117,166,224,1001,224,-100,224,4,224,102,8,223,223,101,2,224,224,1,223,224,223,1001,66,36,224,101,-87,224,224,4,224,102,8,223,223,101,2,224,224,1,223,224,223,1101,26,51,225,1102,11,61,224,1001,224,-671,224,4,224,1002,223,8,223,1001,224,5,224,1,223,224,223,1101,59,77,224,101,-136,224,224,4,224,1002,223,8,223,1001,224,1,224,1,223,224,223,1101,11,36,225,1102,31,16,225,102,24,217,224,1001,224,-1656,224,4,224,102,8,223,223,1001,224,1,224,1,224,223,223,101,60,169,224,1001,224,-147,224,4,224,102,8,223,223,101,2,224,224,1,223,224,223,1102,38,69,225,1101,87,42,225,2,17,14,224,101,-355,224,224,4,224,102,8,223,223,1001,224,2,224,1,224,223,223,1002,113,89,224,101,-979,224,224,4,224,1002,223,8,223,1001,224,7,224,1,224,223,223,1102,69,59,225,4,223,99,0,0,0,677,0,0,0,0,0,0,0,0,0,0,0,1105,0,99999,1105,227,247,1105,1,99999,1005,227,99999,1005,0,256,1105,1,99999,1106,227,99999,1106,0,265,1105,1,99999,1006,0,99999,1006,227,274,1105,1,99999,1105,1,280,1105,1,99999,1,225,225,225,1101,294,0,0,105,1,0,1105,1,99999,1106,0,300,1105,1,99999,1,225,225,225,1101,314,0,0,106,0,0,1105,1,99999,7,677,677,224,1002,223,2,223,1006,224,329,1001,223,1,223,1007,226,226,224,1002,223,2,223,1006,224,344,1001,223,1,223,1108,226,677,224,102,2,223,223,1005,224,359,1001,223,1,223,1107,226,677,224,1002,223,2,223,1006,224,374,101,1,223,223,1107,677,226,224,1002,223,2,223,1006,224,389,101,1,223,223,7,226,677,224,1002,223,2,223,1005,224,404,101,1,223,223,1008,677,226,224,102,2,223,223,1005,224,419,101,1,223,223,1008,226,226,224,102,2,223,223,1006,224,434,101,1,223,223,107,226,226,224,1002,223,2,223,1005,224,449,1001,223,1,223,108,226,677,224,102,2,223,223,1005,224,464,101,1,223,223,1108,677,226,224,102,2,223,223,1005,224,479,101,1,223,223,1007,226,677,224,102,2,223,223,1006,224,494,101,1,223,223,107,677,677,224,102,2,223,223,1005,224,509,101,1,223,223,108,677,677,224,102,2,223,223,1006,224,524,1001,223,1,223,8,226,677,224,102,2,223,223,1005,224,539,101,1,223,223,107,677,226,224,102,2,223,223,1005,224,554,1001,223,1,223,8,226,226,224,102,2,223,223,1006,224,569,1001,223,1,223,7,677,226,224,1002,223,2,223,1005,224,584,1001,223,1,223,1108,226,226,224,102,2,223,223,1005,224,599,1001,223,1,223,1107,677,677,224,1002,223,2,223,1006,224,614,1001,223,1,223,1007,677,677,224,1002,223,2,223,1006,224,629,1001,223,1,223,108,226,226,224,102,2,223,223,1005,224,644,1001,223,1,223,8,677,226,224,1002,223,2,223,1005,224,659,1001,223,1,223,1008,677,677,224,1002,223,2,223,1006,224,674,1001,223,1,223,4,223,99,226 \ No newline at end of file diff --git a/src/main.rs b/src/main.rs index 74b9f38..2bad024 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,5 +1,5 @@ mod tasks; fn main() { - tasks::day07::run(); + tasks::day05::run(); } diff --git a/src/tasks/day05.rs b/src/tasks/day05.rs index 7d1b543..562e2ac 100644 --- a/src/tasks/day05.rs +++ b/src/tasks/day05.rs @@ -150,65 +150,8 @@ impl IntCodeComputer { } pub fn run_until_end(&mut self) { - let mut op = Op::from(self.pc, &self.ram); - let mut inputs = self.input_storage.iter(); - while op.opcode != OpCode::Terminate { - match op.opcode { - OpCode::Add => { - let r = op.params[0].retrieve(&self.ram) + op.params[1].retrieve(&self.ram); - op.params[2].store(&mut self.ram, r); - self.pc += 4; - } - OpCode::Multiply => { - let r = op.params[0].retrieve(&self.ram) * op.params[1].retrieve(&self.ram); - op.params[2].store(&mut self.ram, r); - self.pc += 4; - } - OpCode::Input => { - let v = inputs.next().expect("Not enough inputs given"); - op.params[0].store(&mut self.ram, *v); - self.pc += 2; - } - OpCode::Output => { - self.output_storage.push(op.params[0].retrieve(&self.ram)); - self.pc += 2; - } - OpCode::JumpIfTrue => { - if op.params[0].retrieve(&self.ram) > 0 { - self.pc = op.params[1].retrieve(&self.ram) as usize; - } else { - self.pc += 3; - } - } - OpCode::JumpIfFalse => { - if op.params[0].retrieve(&self.ram) == 0 { - self.pc = op.params[1].retrieve(&self.ram) as usize; - } else { - self.pc += 3; - } - } - OpCode::LessThan => { - let r = if op.params[0].retrieve(&self.ram) < op.params[1].retrieve(&self.ram) { - 1 - } else { - 0 - }; - op.params[2].store(&mut self.ram, r); - self.pc += 4; - } - OpCode::Equals => { - let r = if op.params[0].retrieve(&self.ram) == op.params[1].retrieve(&self.ram) - { - 1 - } else { - 0 - }; - op.params[2].store(&mut self.ram, r); - self.pc += 4; - } - OpCode::Terminate => {} - } - op = Op::from(self.pc, &self.ram); + if !self.run_until_input_empty() { + panic!("There wasn't enough input given to run until the program halted"); } }