This repository contains a Python implementation of a Sudoku solver using Linear Programming (LP). The solver can handle Sudoku puzzles of varying difficulties and can find multiple solutions if they exist.
- Solves 9x9 Sudoku puzzles
- Utilizes Linear Programming for efficient solving
- Can find all possible solutions for a given puzzle
- Includes a function to fetch Sudoku puzzles from the New York Times website
- Python 3.x
- PuLP library (pip install pulp)
- Requests library (pip install requests)
- 
Clone the repository: git clone https://github.com/choppystick/py-sudoku-solver.git cd sudoku-solver-lp
- 
Install the required libraries: pip install -r requirements.txt
- 
Run the solver: python sudoku_solver.py
By default, the script will fetch a "hard" difficulty Sudoku puzzle from the New York Times website and solve it, displaying all possible solutions.
The Sudoku solver uses Linear Programming to model the Sudoku puzzle as a constraint satisfaction problem. Instead of using brute-force algorithm, it is possible to use a more elegant and efficient approach to solve a Sudoku puzzle.
Linear Programming is a mathematical optimization technique used to find the best outcome in a mathematical model whose requirements are represented by linear relationships. In the context of Sudoku, we're not trying to optimize anything, but rather find a feasible solution that satisfies all the constraints of the puzzle. We can set up a mathematical problem as such:
- 
Variables: We create binary variables x[i,j,k]for each cell (i,j) and possible value k (1-9). Ifx[i,j,k] = 1, it means the value k is placed in cell (i,j).
- 
Constraints: The Sudoku rules are modeled as linear constraints: - Each cell must have exactly one value: ∑k x[i,j,k] = 1for each (i,j)
- Each row must contain each number once: ∑j x[i,j,k] = 1for each i and k
- Each column must contain each number once: ∑i x[i,j,k] = 1for each j and k
- Each 3x3 box must contain each number once: ∑(i,j in box) x[i,j,k] = 1for each box and k
- Pre-filled cells: If cell (i,j) is given as value m, then x[i,j,m] = 1
 
- Each cell must have exactly one value: 
- 
Objective Function: In this case, we don't need to optimize anything, so we set a dummy objective function of 0. 
- 
Solving: We use the PuLP library to model and solve the LP problem. PuLP translates our model into a format that can be solved by various LP solvers. 
- 
Solution Interpretation: After solving, we interpret the results. If x[i,j,k] = 1in the solution, we place value k in cell (i,j) of our Sudoku grid.
- 
Multiple Solutions: To find all solutions, we add a constraint after each solution is found that forces at least one change in the next solution. 
This approach is effective for Sudoku because:
- It naturally expresses the logical constraints of Sudoku.
- LP solvers are highly optimized and can quickly find solutions to large systems of linear equations and inequalities.
- It guarantees finding a solution if one exists, or proving no solution exists if the puzzle is unsolvable.
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
