cleaned up double code in IntCodeComputer
This commit is contained in:
@@ -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
|
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
mod tasks;
|
mod tasks;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
tasks::day07::run();
|
tasks::day05::run();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -150,65 +150,8 @@ impl IntCodeComputer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn run_until_end(&mut self) {
|
pub fn run_until_end(&mut self) {
|
||||||
let mut op = Op::from(self.pc, &self.ram);
|
if !self.run_until_input_empty() {
|
||||||
let mut inputs = self.input_storage.iter();
|
panic!("There wasn't enough input given to run until the program halted");
|
||||||
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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user