How to show a sudoku solution is unique?
Asked Answered
C

7

5

Given a unsolved sudoku, how can one show that it has a unique solution?

Cinder answered 19/2, 2011 at 19:0 Comment(5)
I think this is better for math.stackexchange.comFemur
@BlackBear: Sudoku is not a mathematic problem; it is pure logical deduction.Lands
@Lands So there is no branch of mathematics covering logic? ;-) [However, I do think this post is as good -- or better -- here than on math.sx (oh dear, that abbreviation could get ugly).]Carrington
@pst: Well, yes. But most people think because it’s about numbers it’s about arithmetic. And that’s what most people think when thinking of math.Lands
@Gumbo: Numbers is only a very small slice of mathematics, as you get to higher and higher level maths, you talk less and less about numbers. Sudoku is a mathematical problem not because it has numbers (for which, any arbitrary set of nine distinct symbols can substitute), but because Sudoku is a pure logical deduction.Satirical
T
4

Try to find two solutions.

The simplest algorithm is a brute force recursive algorithm with backtracking. Once you have found the first solution, backtrack and look for a second. This is slow but (unlike algorithms that rely on logic alone) it is guaranteed to be able to find all the solutions eventually. Therefore if this algorithm terminates having found only one solution then that solution must be unique.

This will work for easy problems but could take hours or days for harder problems. There are many optimizations you can use if you need more speed.

A simple optimization is to keep track of a candidate list for each square. At each step find the square with the fewest candidates. If there is only one candidate, choose that number, update the grid and the candidates for the other squares, then continue. If there are ever zero candidates you know that a guess you made previously was wrong so you should backtrack.

More advanced optimizations involve looking for patterns which allow you to deduce numbers without making guesses. Here are some examples:

Tit answered 19/2, 2011 at 19:2 Comment(0)
S
3

There are certain configurations that will ultimately result in a non-unique solution, such as:

* *  *  | * * * | * * *
* *  *  | * * * | * * *
* 12 12 | * * * | * * *
--------+-------+------
* *  *  | * * * | * * *
* *  *  | * * * | * * *
* 12 12 | * * * | * * *
--------+-------+------
* *  *  | * * * | * * *
* *  *  | * * * | * * *
* *  *  | * * * | * * *

where the *s can be any number, and 12 are the sole possibilities in those cells. In this case, there is definitely going to be at least two possible solutions:

* * * | * * * | * * *    * * * | * * * | * * *
* * * | * * * | * * *    * * * | * * * | * * *
* 1 2 | * * * | * * *    * 2 1 | * * * | * * *
------+-------+------    ------+-------+------
* * * | * * * | * * *    * * * | * * * | * * *
* * * | * * * | * * *    * * * | * * * | * * *
* 2 1 | * * * | * * *    * 1 2 | * * * | * * *
------+-------+------    ------+-------+------
* * * | * * * | * * *    * * * | * * * | * * *
* * * | * * * | * * *    * * * | * * * | * * *
* * * | * * * | * * *    * * * | * * * | * * *

without calculating the rest of the board, you can determine that this Sudoku's solution is not unique. However, even if it is possible in certain cases to prove that a puzzle's solution is not unique; the only way to prove that a puzzle's solution is unique is to use brute force to calculate that the set of possible solutions contain only 1 solution.

There are some shortcuts than pure brute force, however you need to take extra care when writing a hybrid solver. Most Sudoku solving techniques allows you to find multiple solutions if they exist but some advanced Sudoku solving techniques rely on the fact that proper Sudoku has unique solution, and may cause you to not be able to find the second solution.

Satirical answered 19/2, 2011 at 19:31 Comment(0)
H
2

Soduko is a CSP to 81 variables, one for each box. Using variable names from A1 to A9 for the top row (left to right), to I1-I9 for the bottom line. The blank boxes have the domain {1,2,3,4,5,6,7,8,9} and that they have already filled a domain consisting of a single value. There are also 27 different constraints "all different", one for each row, column and box 9 boxes.

You can use the AC-3 algorithm for simple patterns or PC-2 for the more difficult ones, but this has more computational cost.

Hubby answered 31/10, 2013 at 9:17 Comment(2)
What is a CSP (in this context)?Berryberryhill
@ClareMacrae constraint satisfaction problemAccroach
V
0

In my opinion the only way is to solve it. If you will be able to solve it (without guessing - only with 100% 'moves') then it means that it has exactly one solution. If you won't be able to solve it, then the only way I see is to use bruteforce algorithm and check how many actual solutions you will be able to find.

Verified answered 19/2, 2011 at 19:5 Comment(0)
O
0

As mentioned above one may use a brute force recursive algorithm with backtracking. I would like to suggest just by applying two times the algorithm once upward; meaning the candidate values increase incrementally while searching, and then employing the algorithm downward, meaning the candidate values are examined in a descending order from maximum possible number to 1, then at least two solutions can be detected. If the results from ascending and descending approaches remain the same, then one can say that the puzzle has a unique solution.

Ortega answered 10/6, 2019 at 18:23 Comment(0)
R
0

Using backtracking technique to exhaust all possible solutions. If you get a solution. Solution counter +1. If counter increase more than 1, you can declare this puzzle have more than 1 solution and exit the program. Otherwise, you have to wait until it finish. If counter = 1, you confirm it has one solution. If counter = 0, there is no solution.

Rubella answered 12/3, 2021 at 10:55 Comment(0)
C
0

A heuristic approach can be used to "force", -or even permit a unique solution, to satisfy a unique 16 min clue iteration. Of course, the formulation of any such algorithm(s) uniquenes must predict or demand a single solution. We have been told that such an algorithm would exact an exponential, burdensome search, let alone, the insistence, " there is no 16 clue valid sudoku"

Crunch answered 22/9, 2024 at 10:58 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.