Crates.io | newdoku |
lib.rs | newdoku |
version | 0.6.1 |
source | src |
created_at | 2022-05-30 21:16:12.42858 |
updated_at | 2022-07-21 20:24:03.128618 |
description | A small library for displaying and solving Sudokus in ANSI-compliant terminals. |
homepage | |
repository | https://github.com/Piturnah/newdoku/ |
max_upload_size | |
id | 597149 |
size | 29,447 |
Simple Sudoku solver written in Rust. Method is inspired by a method briefly outlined in a CS lecture I had that I decided to try and implement based only on my understanding from the lecture.
It is called Newdoku because I started doing this a while ago and forgot about it and decided to restart, hence "New"
[dependencies]
newdoku = { version = "0.6", default-features = false }
use newdoku::Sudoku;
fn main() {
let s = Sudoku::from_str(
"xxxxxxx9xx9x7xx21xxx4x9xxxxx1xxx8xxx7xx42xxx5xx8xxxx748x1xxxx4xxxxxxxxxxxx9613xxx",
)
.unwrap();
println!("{}\n\n{}", s, s.solution(0, false).unwrap());
}
See the docs for more info.
$ git clone https://github.com/Piturnah/newdoku
$ cd newdoku
$ cargo run
$ cargo install newdoku
$ newdoku
OPTIONS:
-f, --file <FILE> Load Sudoku from file
-h, --help Print help information
-q, --quiet No output until finished solving (faster)
-s, --step <STEP> Wait STEP millis between inserts [default: 0]
-u, --uid <UID> Load Sudoku by unique ID
When loading from a file, the parser parses any digit as a number in the sudoku. Any other character other than a newline will be parsed as an empty square.
Example sudoku:
xxxxxxx9xx9x7xx21xxx4x9xxxxx1xxx8xxx7xx42xxx5xx8xxxx748x1xxxx4xxxxxxxxxxxx9613xxx
Gives
+-------+-------+-------+
| . . . | . . . | . 9 . |
| . 9 . | 7 . . | 2 1 . |
| . . 4 | . 9 . | . . . |
+-------+-------+-------+
| . 1 . | . . 8 | . . . |
| 7 . . | 4 2 . | . . 5 |
| . . 8 | . . . | . 7 4 |
+-------+-------+-------+
| 8 . 1 | . . . | . 4 . |
| . . . | . . . | . . . |
| . . 9 | 6 1 3 | . . . |
+-------+-------+-------+
PRs and issues welcome.