parent
762e65126a
commit
b8a4ca01b4
@ -0,0 +1,35 @@
|
||||
Monkey = Struct.new(:id, :items, :operation, :test, :throw_to)
|
||||
|
||||
monkeys = ARGF.read.split("\n\n").map {|raw|
|
||||
raw = raw.lines(chomp: true)
|
||||
id = raw.shift.match(/\d+/)[0].to_i
|
||||
starting_items = raw.shift.match(/: (.+)/)[1].split(", ").map(&:to_i)
|
||||
operation_ = raw.shift.match(/: new = (.+)/)[1]
|
||||
operation = ->(old) { eval(operation_) }
|
||||
test = raw.shift.match(/\d+/)[0].to_i
|
||||
t = raw.shift.match(/\d+/)[0].to_i
|
||||
f = raw.shift.match(/\d+/)[0].to_i
|
||||
throw_to = ->(n) { (n % test).zero? ? t : f }
|
||||
Monkey.new(id, starting_items, operation, test, throw_to)
|
||||
}
|
||||
|
||||
max_worry = monkeys.map(&:test).inject(:*)
|
||||
|
||||
inspections = Hash.new(0)
|
||||
# 20.times do
|
||||
10_000.times do
|
||||
monkeys.each do |monkey|
|
||||
until monkey.items.empty?
|
||||
inspections[monkey.id] += 1
|
||||
|
||||
item = monkey.items.shift
|
||||
item = monkey.operation.(item)
|
||||
# item /= 3
|
||||
item %= max_worry
|
||||
to = monkey.throw_to.(item)
|
||||
monkeys[to].items << item
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
p inspections.values.max(2).inject(:*)
|
Loading…
Reference in new issue