Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
Robin Thoni a2696f01ff README il y a 7 ans
.idea/.idea.uqac-ia-sudoku-csp added stats il y a 7 ans
sample added samples; added MRV strategy il y a 7 ans
uqac-ia-sudoku-csp added arguments; added ConsistentTryCount; added Elapsed; fixed mrv for empty sudoku il y a 7 ans
.gitignore init il y a 7 ans
AUTHORS README il y a 7 ans
README.md README il y a 7 ans
uqac-ia-sudoku-csp.sln init il y a 7 ans

README.md

CSP Sudoku Solver

This is a sudoku solver using Constraint Satisfaction Problem pattern.

Build

  • Command line

    cd uqac-ia-aspirobot
    dotnet restore
    dotnet build
    dotnet run
    
  • Visual Studio
    Run VS, open solution, wait for package restore, click run (F5)

  • Rider
    Run Rider, open solution, wait for package restore, click run (Shift + F10)

Configuration

The program allows 3 optional arguments:

  • Generator type: The generator to use to create/load the sudoku. Possible values:
    • ’-’ (default): Read from std input
    • ‘0’: Empty sudoku
    • filename: load from the specified file
  • Next value chooser: The way to select next value to fill. Possible values:
    • ‘mrv’ (default): Use the Minimum remaining values strategy
    • ‘basic’: Select the first blank value, from up to down and left to right
  • Empty characters: The characters that should be considered as empty cell. Default value: ‘0 .’

Code

This solver is coded in .NET Core (C#) using interfaces to abstract implementation.
Interfaces are in Interfaces/*.cs
Constraints are in Solver/Constraints/*.cs
Sudoku loaders/generators are in Solver/Generators/*.cs
Strategies for choosing next value are in Solver/NextValueChoosers/*.cs
Backtracking search algrithm is in Solver/BacktrackSearch.cs