/colour-puzzle-solver

A python solver for colour sorting puzzle games implementing both breadth-first and depth-first algorithms

Primary LanguagePython

Colour Sort Solver

Build Status codecov CodeFactor

This project is to develop a solver for popular colour sorting puzzle games such as Ball Sort Puzzle (App Store | Google Play) and Water Sort Puzzle (App Store | Android)

About the game

The game is based around a collection of containers that are filled with coloured items. Each container has a limited capacity (for the example games above, 4 items).

The goal is to sort the colours such that all items for each unique colour are moved into the same container following a simple set of rules.

There is no time limit.

Rules

  • You can only move the top most colour from one container to another
  • You can only move a colour into a container if the top most colour is the same, unless the container is empty
  • You can only move a colour into a container that is not already at it's maximum capaicty
  • If there are multiple concurrent items of the same colour in the source contianer, all will be transfered to the destination container until it reaches it's maximum capacity.

How does the solver work

Given a starting pattern the solver can perform either a Breadth-first search or a Depth-first search.

Once a valid solution is found, the search is completed and the final grid and all the moves taken to get there are output.

The starting pattern is provided as a JSON file. Some samples can be found in the levels folder.

Breadth-First Search

The breadth first algorithm will always find the shortest path to a solution, sacraficing the time to find a solution in favour of ensuring the solution is optimal.

The starting pattern is evaluated to find all possible moves and this forms a queue of next patterns. Then each pattern in the queue is evaluted one-by-one, finding all possible moves that have not already been visited and placing them into the queue. This is repeated until the queue is empty or a solution is found.

Depth-First Search

The depth first algorithm will find a solution as quickly as possible. The trade-off here is that the solution may not be an optional solution, but it is found far quicker.

All possible moves are evaluted recursively following down the tree as quickly as possible until a solution is found.

NOTICE: This project is for educational purposes only and bears no affiliation with the linked games above.