Skip to content

Latest commit

 

History

History
111 lines (80 loc) · 3.37 KB

README.md

File metadata and controls

111 lines (80 loc) · 3.37 KB

Chess Challenge

Bartek Andrzejczak

The challenge is to find all unique setups of figures on a chessboard with size M x N, so that they don't beat each other.

How to build it?

sbt assembly

How to run it?

java -jar -Xmx3g target/scala-2.11/chess-challenge-assembly-1.0.jar

How will the output look like?

Hi!

Welcome to ultimate chess challenge solver.
The challenge is to find all unique setups of figures on a chessboard
with size M x N, so that they don't beat each other.

Please provide initial information below.
Chessboard width: 3
Chessboard height: 3
Here are the figures and their keys:
King   => K
Queen  => Q
Bishop => B
Rook   => R
Knight => k

What figures would you like to place on the chessboard?
Please, provide the keys and finish with an empty line:
K
K
R

The algorithm found 4 solutions
This solution was generated for you in 24ms
Would you like to see the solutions? (n/Y) 

. . K
R . .
. . K

. R .
. . .
K . K

K . K
. . .
. R .

K . .
. . R
K . .

Press ENTER to continue...

How does an execution for ultimate challenge looks like?

An ultimate challenge is a challenge of putting:

  • 2 Queens
  • 2 Kings
  • 2 Bishops
  • 1 Knight

on a chessboard of 7 x 7.

Hi!

Welcome to ultimate chess challenge solver.
The challenge is to find all unique setups of figures on a chessboard
with size M x N, so that they don't beat each other.

Please provide initial information below.
Chessboard width: 7
Chessboard height: 7
Here are the figures and their keys:
King   => K
Queen  => Q
Bishop => B
Rook   => R
Knight => k

What figures would you like to place on the chessboard?
Please, provide the keys and finish with an empty line:
Q
Q
K
K
B
B
k

The algorithm found 3063828 solutions
This solution was generated for you in 23839ms
Would you like to see the solutions? (n/Y) n

Is it the only way to solve it?

Of course not! Actually there are two more tries of solving this problems in this very repository:

  • branch breadth-first

    I've tried to use breadth-first search algorithm instead of used here depth-first search algorithm. The problem with breadth-first search algorithm is that it look promising because of the potential for optimization and filtering unfruitful search sub-trees, but it's memory complexity is so high, that I never got an answer from this one.

  • branch fundamentals

    In N Queens problem and probably in all chess related problems there is this concept of fundamental solution. The solutions given by the algorithm can be all generated from the set of fundamental solutions by using combinations of rotations and reflections. The premise of the algorithm implemented on this branch was to generate only the list of fundamental solutions and then generate all other solutions as a variations of fundamental solutions. Generating fundamental solutions was actually much faster, but generating variations was so slow, that this improvement failed. You can read a little more in commit 7257615.