Solving Mastermind-like Problems Using Z3 Theorem Prover
This can be quite easily solved using Z3 theorem prover, once we figure out to set up the constraints.
We have 5 variables, \(\{x_i\}, i=0, 1, 2, 3, 4\) which are constrained by
where \([\cdot]\) is the Iverson Bracket notation (1 if the condition holds, 0 otherwise).
When checking the models for which the conditions are satisfied, we will also check that the number of digits satisfying the conditions holds good, using set intersection.
We solve it using python bindings to Z3, which can be installed in python virtual environment by
| pip install z3-solver | 
Then, we can solve the above by running the following python code:
If we remove the distinct constraint, we get 19 different solutions.
We find that Z3 and other SMT solvers are powerful tools for verification computer programs / hardware designs, perform compiler optimizations, finding bugs etc. And solving Logic puzzles!
References: