You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
15 lines
497 B
15 lines
497 B
p ARGF.readlines(chomp: true).map {|row|
|
|
springs, groups = row.split(" ")
|
|
[springs, groups.scan(/\d+/).map(&:to_i)]
|
|
}.map {|springs, groups|
|
|
unknowns = springs.count(??)
|
|
(0...2**unknowns).map {|arrangement|
|
|
arrangement = arrangement.to_s(2).rjust(unknowns, ?0).chars.map { _1 == ?0 ? ?. : ?# }
|
|
candidate = springs.gsub(??) { arrangement.shift }
|
|
candidate.chars
|
|
.slice_when { _1 != _2 }
|
|
.reject { _1[0] == ?. }
|
|
.map(&:size) == groups
|
|
}.count(&:itself)
|
|
}.sum
|