aboutsummaryrefslogtreecommitdiff
path: root/day23
diff options
context:
space:
mode:
authorNat Lasseter <Nat Lasseter nathan@bytemark.co.uk>2017-12-23 11:33:53 +0000
committerNat Lasseter <Nat Lasseter nathan@bytemark.co.uk>2017-12-23 11:33:53 +0000
commit4f32293785d818f5c31394ef0f85cb729797e053 (patch)
tree91ec66c34cfe583c05d0c54fd1b8152dfa2f1aa3 /day23
parent6166869fbb3254c4d8fa6eb844e5988c33a39608 (diff)
Runtime unacceptably long
Diffstat (limited to 'day23')
-rwxr-xr-xday23/part234
1 files changed, 34 insertions, 0 deletions
diff --git a/day23/part2 b/day23/part2
new file mode 100755
index 0000000..b00d666
--- /dev/null
+++ b/day23/part2
@@ -0,0 +1,34 @@
+#!/usr/bin/env ruby
+
+def valof(reg_file, reg_or_int)
+ if reg_or_int >= 'a' && reg_or_int <= 'z' then
+ return reg_file[reg_or_int] || 0
+ end
+ return reg_or_int.to_i
+end
+
+input = $stdin.readlines.map(&:chomp)
+
+reg = {'a' => 1}
+pc = 0
+
+loop do
+ break if pc < 0 || pc >= input.length
+ istr = input[pc].split
+ case istr[0]
+ when 'set'
+ reg[istr[1]] = valof(reg, istr[2])
+ when 'sub'
+ reg[istr[1]] = valof(reg, istr[1]) - valof(reg, istr[2])
+ when 'mul'
+ reg[istr[1]] = valof(reg, istr[1]) * valof(reg, istr[2])
+ when 'jnz'
+ if valof(reg, istr[1]) != 0 then
+ pc += valof(reg, istr[2])
+ pc -= 1
+ end
+ end
+ pc += 1
+end
+
+puts reg['h']