Skip to content

15 or 8 piece sliding tiles puzzle with ai solver using the fringe search algorithm

License

Notifications You must be signed in to change notification settings

erinlynndownes/react-slide-puzzle

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

React Slide Puzzle

A classic 8 or 15 puzzle that I built with React that has interactive sliding tiles. The ai solver uses the fringe search algorithm and manhattan distance heuristic, which is sufficient for the 8 piece puzzle. For the 15 piece a non-optimal but short solution is found by breaking up the problem and stringing together those solutions, an idea based on this paper by Ian Parberry.

While most configurations of the 15 puzzle are solved within a few seconds, the hardest can take up from 30 to 50 seconds. For this reason the solution is carried out in a web worker so the browser doesn't lock up. This puzzle works great on mobile devices due to the responsive design of the layout and memory efficient ai.

Demo

https://slidepuzzletest.erinlynnlouise.net/

Getting started

start

First clone the repo to your local server and then install dependencies and start.
```
npm install
npm start
```

build

npm run build

Built with

Create React App

License

This project is licensed under the MIT License - see the LICENSE.txt file for details

Acknowledgements

Since I was using this project to learn React, I took inspiration from https://github.com/cedricblondeau/sliding-puzzle and https://github.com/unindented/react-puzzle.

The 15-puzzle solution is based on the idea from Ian Parberry's paper A Memory-Efficient Method for Fast Computation of Short 15-Puzzle Solutions

Fringe Search adapted from psuedocode at https://en.wikipedia.org/wiki/Fringe_search

About

15 or 8 piece sliding tiles puzzle with ai solver using the fringe search algorithm

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published