This repository contains the code for a Sudoku.com Solver, which was created for a YouTube video on backtracking algorithms. In the video, I use the game of Sudoku since its perfect to solve using backtracking, it's simple, and everyone knows it. This project includes:
The core of the solver is the backtracking algorithm. I implemented a classic backtracking approach to solve the Sudoku. The pruning involves checking the validity of the Sudoku at each step, ensuring the efficiency of the solver. Nothing too fancy.
- Trivial Moves Optimization: One of the optimizations included is the step I called "Trivial Moves". This feature allows the solver to iteratively fill cells where only one possible number can go, significantly speeding up the solving process.
- Least Possible Options: Another optimization I introduced is a strategy that starts with the cells having the least possible options. By prioritizing these cells, the solver can make more informed and efficient decisions during the backtracking process, leading to faster puzzle resolution.
I implemented computer vision and image processing techniques to capture the Sudoku puzzle directly from the screen. This way, users can simply display the puzzle on their screen, and the solver will recognize it automatically.
To recognize the digits within the Sudoku puzzle, I employed a simple K-Nearest Neighbors (KNN) model. This model allows the solver to read the digits from the captured image with accuracy.
The project also utilizes GUI automation to interact with the Sudoku.com website. The solver automatically clicks on each cell and inputs the correct digit using the computer vision and machine learning components.