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…
Reference in new issue