[2020][ruby][22.x]

pull/2/head
Alpha Chen 4 years ago
parent 2c8cff45b0
commit f40f2356d3

@ -0,0 +1,46 @@
require "set"
decks = ARGF.read.split("\n\n").map {|players| players.split("\n")[1..].map(&:to_i) }
# part one
# until decks.any?(&:empty?)
# p decks
# top_cards = decks.map(&:shift)
# fail if top_cards.tally.size == 1
# if top_cards.first > top_cards.last
# decks.first.concat(top_cards)
# else
# decks.last.concat(top_cards.reverse)
# end
# end
SEEN = Set.new
def recursive_combat!(decks)
until decks.any?(&:empty?)
return 0 if SEEN.include?(decks)
SEEN << decks
top_cards = decks.map(&:shift)
winner = if decks.zip(top_cards).all? {|d,tc| d.size >= tc }
recursive_combat!(decks.zip(top_cards).map {|d,tc| d[0,tc] })
elsif top_cards.first > top_cards.last
0
else
1
end
if winner == 0
decks.first.concat(top_cards)
else
decks.last.concat(top_cards.reverse)
end
end
decks.index {|d| !d.empty? }
end
recursive_combat!(decks)
p decks.flatten.reverse.map.with_index {|v,i| v * (i+1) }.sum
Loading…
Cancel
Save