sudoku/README.md

63 lines
1.2 KiB
Markdown

# Sudoku solver
A simple sudoku problem solver because I got bored of solving them manually.
## File format
The sudoku solver accepts a file for the following format:
* Each row consists of 9 characters (+ newline)
* Each character on a row (aside from newline) must be '0'-'9' or ' ' (if value is unknown)
* There must be a total of 9 rows
For example, a file might look as follows:
```
23456789
2 4567891
34 678912
456 89123
5678 1234
67891 345
789123 56
8912345 7
91234567
```
or
```
123456789
2 456 891
3456789
456 89123
5678 12 4
6 91 345
789123456
8 12345 7
912345678
```
## Compiling and running
To test the functionality, simply run `gcc -o sudoku main.c board.c`, then
`./sudoku [filename]`, where the given file is formatted according to the
aforementioned specifications.
## Optimization
An optimization directive has been included in `board.c` to allow for the near
complete removal of boundary checks and error conditions. To enable this
optimization, simply add `-DOPTIMIZE` to your compiler flags.
## TODO
* Optimizations
* Per-quadrant bit-field of populated values
* Packed structures
* Better structure layouts
* Better error messages
* Makefile