8 Queens Problem
Last updated
Last updated
The eight queens puzzle is the problem of placing eight chess queens on an 8×8 chessboard so that no two queens threaten each other; thus, a solution requires that no two queens share the same row, column, or diagonal.
The above images represent the distribution of solutions for the eight queens puzzle. The original images can be viewed in the gallery.
The game rules are handled by the PiecesBoardState
type using the following configuration:
Property
Value
Description
Dimension
8
Size of the board
Piece
QueenPiece
Defines how the piece moves on the board
OnlySafeMoves
true
Game state will only return moves that do not attack existing queens
Next the results mapper (EightQueensProblemSolutionTreeMapper
) will take the game tree and transform it into a tree containing the results we can use generate the visualisation. In this case we are given a game tree 3 moves deep and then collect our results using the EightQueensProblemSolutionAggregate
type.
We then have a tree painter (EightQueensProblemPainter
) which maps the results tree into a colour tree.
The EightQueensProblemPainter
normalises the number of wins of a tree node against the maximum value of its siblings.
E.g. if we have 3 child nodes: [100, 10, 50], the max sibling value is 100 so the normalised result will be [100/100, 10/100, 50/100] or [1, 0.1, 0.5]
The GoldInterpolator then takes this normalised value and converts it to a colour.
All unavailable moves will be coloured black, with the exception of moves that are the same as the previous. The relevant code segment is here:
Returning a null node will be ignored by the renderer. This means the null nodes will be coloured according to the parent's results which acts like a summary at each depth:
The SquareTreeRenderer
fits very nicely with this type of problem as it is played on a 8x8 board.
Property
Value
MaxDepth
1, 2 and 3