parent
a0a54eefff
commit
5c4b1cb37e
@ -0,0 +1,29 @@
|
|||||||
|
places = (0..).lazy.map { 5 ** _1 }
|
||||||
|
digits = { ?- => -1, ?= => -2 }
|
||||||
|
|
||||||
|
sum = ARGF.read.lines(chomp: true)
|
||||||
|
.map {|snafu|
|
||||||
|
snafu.reverse.chars
|
||||||
|
.map { digits.fetch(_1, _1.to_i) }
|
||||||
|
.zip(places)
|
||||||
|
.map { _1 * _2 }
|
||||||
|
.sum
|
||||||
|
}.sum
|
||||||
|
|
||||||
|
n_places = places.slice_after { 2*_1 >= sum }.take(1).to_a.flatten.reverse
|
||||||
|
|
||||||
|
require "z3"
|
||||||
|
|
||||||
|
solver = Z3::Solver.new
|
||||||
|
|
||||||
|
n_places.each do |place|
|
||||||
|
solver.assert Z3.Int(place.to_s) <= 2
|
||||||
|
solver.assert Z3.Int(place.to_s) >= -2
|
||||||
|
end
|
||||||
|
solver.assert n_places.map { _1 * Z3.Int(_1.to_s) }.sum == sum
|
||||||
|
|
||||||
|
fail unless solver.satisfiable?
|
||||||
|
p n_places
|
||||||
|
.map { solver.model[Z3.Int(_1.to_s)].to_i }
|
||||||
|
.map { digits.invert.fetch(_1, _1) }
|
||||||
|
.join
|
Loading…
Reference in new issue