wip
Alpha Chen 9 years ago
parent 898b6b0c06
commit 9aa2c9980b

@ -1,12 +1,32 @@
class Reindeer
attr_reader *%i[ speed time rest ]
def initialize(speed, time, rest)
@speed, @time, @rest = [speed, time, rest].map(&:to_i)
end
def distance(current_time)
distance = speed * time
total_time = time + rest
reps = current_time / total_time
reps * distance + [current_time % total_time, time].min * speed
end
end
regex = /(\w+) can fly (\d+) km\/s for (\d+) seconds, but then must rest for (\d+) seconds/ regex = /(\w+) can fly (\d+) km\/s for (\d+) seconds, but then must rest for (\d+) seconds/
puts DATA.read.scan(regex).map { |name, speed, time, rest| reindeer = DATA.read.scan(regex).each.with_object({}) {|(name, speed, time, rest), reindeer|
distance = speed.to_i * time.to_i reindeer[name] = Reindeer.new(speed, time, rest)
total_time = time.to_i + rest.to_i }
reps = 2503 / total_time
scores = (1..2503).each.with_object(Hash.new(0)) do |current_time, scores|
sorted = reindeer.group_by {|_,r| r.distance(current_time) }.sort
sorted.last.last.map(&:first).each do |name|
scores[name] += 1
end
end
total_distance = reps * distance + [2503 % total_time, time.to_i].min * speed.to_i puts scores.sort_by(&:last)
[name, total_distance]
}.max {|a,b| a.last <=> b.last }
__END__ __END__
Dancer can fly 27 km/s for 5 seconds, but then must rest for 132 seconds. Dancer can fly 27 km/s for 5 seconds, but then must rest for 132 seconds.
Cupid can fly 22 km/s for 2 seconds, but then must rest for 41 seconds. Cupid can fly 22 km/s for 2 seconds, but then must rest for 41 seconds.

Loading…
Cancel
Save