Skip to main content

Sudoku Solver in pure Python with no dependencies

Project description

Build Status

Sudoku Solver written in pure Python with no dependencies.

It solves Sudokus of sizes N x N by pure induction as far as is possible, and then uses an optional Dancing Links solver, which is a brute force methodology, when the basic induction is not enough.

Installation

Install by calling:

pip install git+https://github.com/hbldh/dlxsudoku

Testing

Tests can be run using nosetests:

nosetests tests

The tests make a HTTP request to a file containing several Sudokus on Project Euler.

Usage

A Sudoku stored in a file can be solved as such:

from dlxsudoku import Sudoku

s = Sudoku.load_file('path/to/sudoku.sud')
s.solve(verbose=True, allow_brute_force=True)

Alternatively, if your Sudoku is stored in string variable it can be solved in the following fashion:

from dlxsudoku import Sudoku

sudoku_string_1 = "030467050920010006067300148301006027400850600090200400005624001203000504040030702"
sudoku_string_2 = "# Example Sudoku\n" + \
                  "*72****6*\n" + \
                  "***72*9*4\n" + \
                  "*9*1****2\n" + \
                  "*******4*\n" + \
                  "82*4*71**\n" + \
                  "**9*6*8**\n" + \
                  "***9**6**\n" + \
                  "**3*72*9*\n" + \
                  "*6*843*7*"

s1 = Sudoku(sudoku_string_1)
s1.solve()
print(s1.to_oneliner())

s2 = Sudoku(sudoku_string_2)
s2.solve()
print(s2)

Sudoku formatting

A Sudoku file or string should be structured in the following manner:

# Optional comment or metadata
*72****6*
***72*9*4
*9*1****2
*******4*
82*4*71**
**9*6*8**
***9**6**
**3*72*9*
*6*843*7*

or as a one-liner:

030467050920010006067300148301006027400850600090200400005624001203000504040030702

Any character other than [1-9] may be used as a placeholder for unknowns.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dlxsudoku-0.9.2.tar.gz (14.6 kB view details)

Uploaded Source

Built Distribution

dlxsudoku-0.9.2-py2.py3-none-any.whl (11.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file dlxsudoku-0.9.2.tar.gz.

File metadata

  • Download URL: dlxsudoku-0.9.2.tar.gz
  • Upload date:
  • Size: 14.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for dlxsudoku-0.9.2.tar.gz
Algorithm Hash digest
SHA256 5f0eecd1f64ea87271501b8c6a41bb9388a29aad4d0c1aad02c42b1334b19b0e
MD5 16838ee7a41e0ee43932687429f4f9f0
BLAKE2b-256 0ee7a7258f6df7a184fe5a11f73ecd9562078877fedd2612d45419a26f61dde2

See more details on using hashes here.

File details

Details for the file dlxsudoku-0.9.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for dlxsudoku-0.9.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 561b7e657ebc6269727eaf1eb44ee62f95937d1f3cdf58ec1e8664c547a2c427
MD5 bf7e407d9f5ca11155a1045b9d906179
BLAKE2b-256 d913c6e413ec95c945b61b5006f1158b432a483ed878a74938a4b7084c03d03b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page