Skip to content

A tool for visualizing pathfinding algorithms, allowing users to create mazes and watch their solution using popular algorithms such as DFS, BFS, Dijkstra, and A*.

License

Notifications You must be signed in to change notification settings

agrigoridou/Pathfinding-Visualizer-DFS-BFS-Dijkstra-Astar

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pathfinding-Visualizer(DFS-BFS-Dijkstra-A*)

Visualization of pathfinding algorithms, allowing users to create mazes and track their solution using popular algorithms such as DFS, BFS, Dijkstra, and A*.

image

Features

  • Algorithm Visualization: See in real-time how DFS, BFS, Dijkstra, and A* algorithms search for a path through a maze.
  • Maze Creation: Create custom mazes by placing walls, as well as start and end points.
  • Random Mazes: Generate random mazes to test the algorithms.
  • Clearing: Easily remove walls and reset the grid for a new search.

Prerequisites

To run this project, you will need:

  • Python 3.x
  • Pygame

To install the required libraries, run the following command:

pip install pygame

Installation Instructions

  • Clone the repository or download the files.
  • Ensure that you have installed the prerequisites.
  • Run main.py to start the application.

Usage Instructions

  • Starting: Once the application starts, a grid will appear.
  • Placing Walls: Use right-click to place walls and left-click to set the start or end point.
  • Running Algorithms: Press the Enter key to select an algorithm and then press the corresponding buttons for DFS, BFS, Dijkstra, or A* to view their visualization.
  • Random Mazes: Click the "Random Maze" button to generate a random maze.
  • Clearing: Use the "Clear" button to remove all walls and reset the grid.

Code Structure

  • main.py: The entry point of the application.
  • gui.py: Contains the Gui class that manages the graphical user interface and interactions.
  • pathfinding_algorithms: Folder containing the code for the pathfinding algorithms and maze handling.
  • coordinates.py: Contains the Coordinates class for managing the maze and the algorithms' paths.
  • pathfinding.py: Contains the Pathfinding class with methods implementing the DFS, BFS, Dijkstra, and A* algorithms.

Example Results

DFS BFS Dijkstra A*
DFS Example GIF BFS Example GIF Dijkstra Example GIF A* Example GIF

About

A tool for visualizing pathfinding algorithms, allowing users to create mazes and watch their solution using popular algorithms such as DFS, BFS, Dijkstra, and A*.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages