Skip to content

A web-based interactive platform for visualizing various data structures and algorithms, including sorting and searching techniques. Users can explore and understand the mechanics of algorithms through dynamic visual representations.

License

Notifications You must be signed in to change notification settings

Renu-code123/AlgoVisualizer

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

๐ŸŽฏ AlgoVisualizer

GSSoC'25 GSSoC-OpenSource Built with Love PRs Welcome

๐Ÿ“– Table of Contents

๐Ÿ” Overview

Welcome to AlgoVisualizer, a cutting-edge interactive web application designed to transform the way you learn and understand algorithms. Experience real-time visualizations of sorting, searching, and data structure algorithms with a beautiful, modern interface.

๐Ÿš€ Live Demo: https://algo-visualizer-amber.vercel.app

Thanks Banner Typing SVG

๐Ÿ“Š Project Insights

๐ŸŒŸ Stars ๐Ÿด Forks ๐Ÿ› Issues ๐Ÿ”” Open PRs ๐Ÿ”• Closed PRs ๐Ÿ› ๏ธ Languages ๐Ÿ‘ฅ Contributors
Stars Forks Issues Open PRs Closed PRs Languages Count Contributors Count

โœจ Features

๐ŸŽจ Modern Interface

  • Dark Theme: Sleek GitHub-inspired dark theme for comfortable learning
  • Interactive Learning Platform: Intuitive badge-based navigation system
  • Responsive Design: Seamless experience across desktop, tablet, and mobile devices
  • Smooth Animations: Powered by Framer Motion for engaging user experience

๐Ÿ“ User Input System

  • ๐Ÿ“Š Custom Data Visualization: Upload your own arrays, graphs, and data structures
  • ๐ŸŽฏ Multiple Input Methods: Text input, file upload (JSON/CSV/TXT), and sample data
  • โœ… Smart Validation: Real-time data validation with helpful error messages
  • ๐Ÿ“‹ Format Support: JSON, CSV, comma-separated values, and structured data
  • ๐Ÿ”ง Auto-Processing: Automatic sorting for search algorithms, ID generation for graphs
  • ๐Ÿ“š Sample Library: Built-in examples for all algorithm types (arrays, graphs, trees)
  • ๐Ÿ“„ File Export: Download sample data or save your custom datasets

๐Ÿง  Algorithm Visualizations

  • Step-by-Step Visualization: Watch algorithms execute in real-time with clear visual feedback
  • Interactive Controls: Play, pause, reset, and adjust speed of algorithm execution
  • Performance Metrics: Track comparisons, swaps, iterations, and execution time
  • Code Explanation: Detailed code walkthrough with syntax highlighting

๐Ÿ“Š Export & Recording

  • ๐Ÿ“ธ High-Quality Snapshots: Capture visualization states as PNG/JPEG images
  • ๐ŸŽฌ Video Recording: Export complete algorithm runs as GIFs or MP4 videos
  • โš™๏ธ Customizable Settings: Adjust frame rates, quality, and export formats
  • ๐Ÿ“š Educational Ready: Perfect for presentations, tutorials, and documentation

๐ŸŽ“ Learning Tools

  • Interactive Quiz System: Test your algorithm knowledge with built-in quizzes
  • Algorithm Documentation: Comprehensive guides and explanations
  • Contributors Section: Meet the amazing people behind the project
  • About & Contact Pages: Learn more about the project and get in touch

๐ŸŒŸ Exciting News...

๐Ÿš€ This project is now an official part of GirlScript Summer of Code โ€“ GSSoC'25! ๐Ÿ’ƒ๐ŸŽ‰๐Ÿ’ป We're thrilled to welcome contributors from all over India and beyond to collaborate, build, and grow AlgoVisualizer! Letโ€™s make learning and career development smarter โ€“ together! ๐ŸŒŸ๐Ÿ‘จโ€๐Ÿ’ป๐Ÿ‘ฉโ€๐Ÿ’ป

๐Ÿ‘ฉโ€๐Ÿ’ป GSSoC is one of Indiaโ€™s largest 3-month-long open-source programs that encourages developers of all levels to contribute to real-world projects ๐ŸŒ while learning, collaborating, and growing together. ๐ŸŒฑ

๐ŸŒˆ With mentorship, community support, and collaborative coding, it's the perfect platform for developers to:

  • โœจ Improve their skills
  • ๐Ÿค Contribute to impactful projects
  • ๐Ÿ† Get recognized for their work
  • ๐Ÿ“œ Receive certificates and swag!

๐ŸŽ‰ I canโ€™t wait to welcome new contributors from GSSoC 2025 to this AlgoVisualizer project family! Let's build, learn, and grow together โ€” one commit at a time. ๐Ÿ”ฅ๐Ÿ‘จโ€๐Ÿ’ป๐Ÿ‘ฉโ€๐Ÿ’ป

๐Ÿ” Supported Algorithms

Sorting Algorithms (7 Total)

  • Bubble Sort - Simple comparison-based sorting
  • Insertion Sort - Efficient for small datasets
  • Selection Sort - In-place comparison sorting
  • Merge Sort - Divide and conquer approach
  • Quick Sort - Efficient average-case performance
  • Bucket Sort - Distribution-based sorting
  • Radix Sort - Non-comparison integer sorting

Searching Algorithms (4 Total)

  • Linear Search - Sequential search through elements
  • Binary Search - Efficient search on sorted arrays
  • Jump Search - Block-based search optimization
  • Exponential Search - Combination of binary and unbounded search

Data Structures (6 Total)

  • Stack - LIFO (Last In, First Out) operations
  • Queue - FIFO (First In, First Out) operations
  • Linked List - Dynamic linear data structure
  • Binary Tree - Hierarchical tree structure
  • Binary Search Tree - Ordered binary tree with search properties
  • Graph Algorithms - Network and connectivity visualizations

๐Ÿ’ป Code Implementations

AlgoVisualizer provides ready-to-use code implementations for all visualized algorithms in multiple programming languages. This feature makes it perfect for learning, reference, and direct use in your projects.

๐ŸŒŸ Code Section Features

  • ๐Ÿ“š Multiple Languages: View implementations in Java, Python, and C++
  • ๐Ÿ”„ Language Switching: Easy toggle between programming languages with a single click
  • ๐Ÿ“‹ Copy-Ready Code: All code is production-ready and can be directly copied
  • ๐Ÿ“– Educational Focus: Clean, well-commented code perfect for learning
  • ๐ŸŽฏ Algorithm Coverage: Comprehensive coverage of all visualized algorithms

๐ŸŽจ Available Code Categories

Sorting Algorithms

Complete implementations for all sorting algorithms including:

  • Bubble Sort, Selection Sort, Insertion Sort
  • Merge Sort, Quick Sort, Shell Sort
  • Radix Sort, Bucket Sort, Heap Sort
  • Tim Sort, Intro Sort, Counting Sort

Searching Algorithms

Efficient search implementations:

  • Linear Search - Sequential element scanning
  • Binary Search - Logarithmic search on sorted arrays
  • Ternary Search - Three-way division search
  • Jump Search - Block-based optimization
  • Exponential Search - Range finding + binary search

Graph Algorithms

Network and connectivity algorithms:

  • BFS (Breadth-First Search) - Level-order traversal
  • DFS (Depth-First Search) - Deep exploration traversal
  • Dijkstra's Algorithm - Shortest path finding
  • Bellman-Ford Algorithm - Negative edge handling
  • Floyd-Warshall Algorithm - All-pairs shortest paths

Linked List Operations

Complete linked list functionality:

  • Insert Operations: Beginning, End, At Position
  • Delete Operations: By Value, By Position
  • Utility Operations: Search, Traverse, Reverse
  • List Management: Size calculation, Clear operations

Other Algorithms

Additional algorithmic implementations:

  • Morris Traversal, Dutch National Flag
  • Kahn's Algorithm, Tarjan's Algorithm
  • Tower of Hanoi, Kadane's Algorithm

๐Ÿš€ How to Use the Code Section

  1. Navigate to any algorithm page (Sorting, Searching, Graph, etc.)
  2. Scroll to the "Code Implementation" section at the bottom
  3. Select your preferred language using the language tabs (Java/Python/C++)
  4. Copy the code directly from the syntax-highlighted code block
  5. Use in your projects - all code is production-ready!

๐Ÿ“ Code Quality & Standards

  • โœ… Production Ready: All implementations are tested and optimized
  • ๐Ÿ“š Educational: Clear variable names and logical structure
  • ๐Ÿ”ง Modular: Easy to integrate into existing projects
  • ๐Ÿ“– Well Documented: Inline comments explain key concepts
  • ๐ŸŽฏ Efficient: Implementations follow best practices for each language

๐Ÿ› ๏ธ Language-Specific Features

Java Implementations

  • Object-oriented design patterns
  • Generic programming with Collections
  • Exception handling where appropriate
  • Standard Java conventions and style

Python Implementations

  • Pythonic code style and idioms
  • List comprehensions and built-in functions
  • Type hints for better code clarity
  • PEP 8 compliant formatting

C++ Implementations

  • Modern C++ features (C++11 and later)
  • STL containers and algorithms
  • Memory management best practices
  • Template programming where beneficial

๐Ÿ“Š Code Complexity Information

Each code section includes detailed complexity analysis:

  • โฑ๏ธ Time Complexity: Best, average, and worst-case scenarios
  • ๐Ÿ’พ Space Complexity: Memory usage analysis
  • ๐Ÿ“‹ Algorithm Description: Clear explanation of how it works
  • ๐ŸŽฏ Use Cases: Real-world applications and when to use each algorithm

๐ŸŽ“ Perfect for Learning

The code implementations are ideal for:

  • ๐Ÿ‘จโ€๐ŸŽ“ Students learning data structures and algorithms
  • ๐Ÿ‘ฉโ€๐Ÿ’ป Developers preparing for coding interviews
  • ๐Ÿซ Educators creating teaching materials
  • ๐Ÿ“š Self-learners exploring algorithmic concepts
  • ๐Ÿš€ Project Developers needing quick algorithm implementations

๐Ÿ’ก Pro Tips

  • Compare Languages: Switch between languages to see different implementation approaches
  • Study Patterns: Notice how similar algorithms are structured across languages
  • Experiment: Modify the code to understand how changes affect performance
  • Practice: Use the visualizations alongside code to understand execution flow

๐Ÿ› ๏ธ Technologies Used

Frontend

  • React 18.3.1 - Modern component-based UI framework
  • Framer Motion 12.23 - Smooth animations and transitions
  • React Router Dom 6.30 - Client-side routing
  • Lucide React - Beautiful icon library
  • CSS3 - Modern styling with custom properties and grid layouts

Development Tools

  • Vite 5.0 - Fast build tool and development server
  • ESLint - Code quality and consistency
  • HTML2Canvas - Screenshot and image capture
  • GIF.js - GIF creation and export
  • RecordRTC - Video recording capabilities

Deployment & Analytics

  • Vercel - Serverless deployment platform
  • Vercel Analytics - User behavior and performance tracking

Visualization Logic Explained

The heart of this project is AlgorithmVisualizer.jsx. Hereโ€™s how it works:

  • State Management: Handles the array of numbers to be sorted and updates the UI as the algorithm progresses.

  • Dynamic Bar Width: Bar size is now calculated dynamically based on screen size and the number of elements โ€” so the visualizer is fully responsive.

  • Sorting Algorithms: The algorithms (Bubble Sort, Merge Sort, Quick Sort, etc.) are imported from the src/algorithms/ folder. Each runs step-by-step with animated transitions.

  • Styling: The visualization container and bars are styled in UnifiedVisualizer.css for a clean, responsive layout.

Quick Start

Prerequisites

  • Node.js 20.11.1 or higher
  • npm or yarn package manager

Installation

  1. Clone the repository:

    git clone https://github.com/<your-username>/AlgoVisualizer.git 
    Example:
    git clone https://github.com/RhythmPahwa14/AlgoVisualizer.git
    cd AlgoVisualizer
  2. Install dependencies:

    npm install --legacy-peer-deps
  3. Start the development server:

    npm run dev
  4. Open your browser:

    Navigate to http://localhost:5173/ to view the application.

Build for Production

npm run build
npm run preview

๐ŸŽฎ Usage Guide

๐Ÿ  Home Page

  • Interactive learning platform badge at the top
  • Algorithm showcase with rotating examples
  • Direct navigation to different algorithm categories

๐Ÿ“Š Sorting Algorithms

  1. Load Your Data: Use the enhanced input panel to:
    • Enter numbers directly: 64, 34, 25, 12, 22, 11, 90
    • Upload a JSON file: [64, 34, 25, 12, 22, 11, 90]
    • Try sample data with different characteristics
  2. Select your preferred sorting algorithm
  3. Adjust visualization speed
  4. Click "Start Sorting" to begin
  5. Use export controls to capture or record the process

๐Ÿ” Searching Algorithms

  1. Input Your Array: Load custom data (auto-sorted for searching):
    • Direct input: 5, 12, 19, 23, 45, 67, 89
    • File upload: CSV or JSON format
    • Sample sorted arrays available
  2. Choose a searching algorithm
  3. Specify the target value to search
  4. Watch the step-by-step search process
  5. Export visualizations for educational use

๐Ÿ•ธ๏ธ Graph Algorithms

  1. Create Your Graph: Use the input panel to define:
    {
      "nodes": [{"id": 0, "label": "A"}, {"id": 1, "label": "B"}],
      "edges": [{"id": "0-1", "from": 0, "to": 1, "weight": 5}]
    }
  2. Load sample graphs (simple, complex, weighted, cycle detection)
  3. Select algorithm (BFS, DFS, Dijkstra)
  4. Watch the traversal or pathfinding in action

๐ŸŒณ Data Structures

  • Explore interactive data structure operations
  • Load custom tree/linked list data
  • Visualize insertions, deletions, and traversals
  • Understand structural relationships and properties

๐Ÿ“ Custom Data Input Features

  • Multiple Formats: JSON, CSV, TXT file support
  • Real-time Validation: Instant feedback on data format
  • Sample Data Library: Examples for every algorithm type
  • Auto-correction: Missing IDs and labels auto-generated
  • Error Guidance: Clear instructions for fixing data issues

๐ŸŽ“ Quiz Section

  • Test your algorithm knowledge
  • Multiple choice questions with immediate feedback
  • Track your learning progress

๐Ÿ“ Project Structure

AlgoVisualizer/
โ”œโ”€โ”€ public/                 # Static assets
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ algorithms/         # Algorithm implementations
โ”‚   โ”œโ”€โ”€ components/         # Reusable React components
โ”‚   โ”œโ”€โ”€ data/              # Static data and configurations
โ”‚   โ”œโ”€โ”€ hooks/             # Custom React hooks
โ”‚   โ”œโ”€โ”€ pages/             # Main application pages
โ”‚   โ”œโ”€โ”€ styles/            # CSS styling files
โ”‚   โ””โ”€โ”€ utils/             # Utility functions and helpers
โ”œโ”€โ”€ package.json           # Project dependencies and scripts
โ””โ”€โ”€ README.md             # Project documentation

Getting Started With Contributions

  1. Fork the repository
# Fork the repository on GitHub, then clone your fork:
git clone https://github.com/your-username/AlgoVisualizer.git
cd AlgoVisualizer
  1. Set Up Upstream
# Add the original repository as upstream:
git remote add upstream https://github.com/RhythmPahwa14/AlgoVisualizer.git
git fetch upstream
  1. Create your feature branch
# Create a new branch for your feature or bug fix:
git checkout -b feature/your-feature-name
# or
git checkout -b fix/your-bug-fix
  1. Commit your changes
# Stage and commit your changes:
git add .
git commit -m "feature: add awesome feature"
  1. Push to the branch & Create PR
# Push your branch to your fork and open a Pull Request:
git push origin feature/your-feature-name

Then go to AlgoVisualizer Pull Requests and create a PR with a clear description of your changes.

Code Style

  • Follow existing code conventions
  • Add comments for complex algorithms
  • Ensure responsive design for all new features
  • Test your changes across different devices

๐Ÿ“ˆ Analytics & Performance

This application uses Vercel Analytics to track:

  • Page views and user engagement
  • Performance metrics and load times
  • Feature usage patterns
  • Geographic user distribution

All data is collected anonymously and helps us improve the user experience.

๐ŸŽฏ Educational Impact

Perfect for:

  • Students learning data structures and algorithms
  • Teachers creating interactive classroom materials
  • Developers preparing for technical interviews
  • Content Creators making educational videos and tutorials
  • Bootcamps and coding schools

๐Ÿง‘โ€๐Ÿ’ป Project Admins

Meet our amazing project admins:

Rhythm
Rhythm
LinkedIn
Sandeep
Sandeep Vashishtha
LinkedIn

๐Ÿ† Contributors

Meet our amazing contributors:

Want to see your name here? Contribute to the project!

๐Ÿ“„ Documentation

๐Ÿ“Š Project Stats

  • 15+ Algorithms implemented with visualizations
  • 6 Data Structures with interactive operations
  • Mobile Responsive design for all devices
  • Modern Tech Stack with React 18 and Vite
  • Export Capabilities for educational content creation

๐Ÿ”ฎ Future Roadmap

  • ๐ŸŒ Graph Algorithms: Advanced graph traversal and pathfinding
  • ๐Ÿ”ข Mathematical Algorithms: Number theory and computational mathematics
  • ๐ŸŽฎ Gamification: Achievement system and learning badges
  • ๐ŸŒ Internationalization: Multi-language support
  • ๐Ÿค– AI Integration: Algorithm recommendation system

๐Ÿ™ Acknowledgments

  • Thanks to all contributors of this project
  • Special shoutout to GirlScript Summer of Code (GSSoCโ€™25) for the amazing community and support!
  • Built with dedication, collaboration, and lots of chai

๐Ÿ“ž Contact

๐ŸคHow to Contribute

We love contributions from the community! Whether it's a bug report, a new feature, or a documentation improvement, we appreciate your help.

How to Contribute

  1. Fork and clone the repository and create a new branch for your changes.
  2. Make your changes and ensure everything is working as expected.
  3. Submit a pull request with a clear description of your changes.

or check out Getting Started With Contributions

Found a Bug?

  • Check the issue tracker to see if the bug has already been reported.
  • If not, open a new issue and provide as much detail as possible.

Have a Feature Idea?

  • We'd love to hear it! Open an issue to discuss your idea.

๐Ÿค Contributing

We welcome contributions from the community! Here's how you can help:

Ways to Contribute

  • ๐Ÿ› Report Bugs: Found an issue? Let us know!
  • ๐Ÿ’ก Suggest Features: Have ideas for improvements?
  • ๐Ÿ“ Improve Documentation: Help make our docs better
  • ๐ŸŽจ Design Improvements: Enhance the user interface
  • โšก Performance Optimizations: Make the app faster
  • ๐Ÿงช Add Algorithms: Implement new visualization algorithms

๐Ÿ“œ Code of Conduct

Please refer to the Code of Conduct for details on contributing guidelines and community standards.

๐Ÿค๐Ÿ‘ค Contribution Guidelines

We love our contributors! If you'd like to help, please check out our CONTRIBUTE.md file for guidelines.

Thank you once again to all our contributors who has contributed to AlgoVisualizer! Your efforts are truly appreciated. ๐Ÿ’–๐Ÿ‘

Contributors

Contributors

See the full list of contributors and their contributions on the GitHub Contributors Graph.

Show some Red Heart by starring this awesome repository!

๐Ÿ’ก Suggestions & Feedback

Feel free to open issues or discussions if you have any feedback, feature suggestions, or want to collaborate!

๐Ÿ™Œ Show Your Support

If you find AlgoVisualizer project helpful, give it a star! โญ to support more such educational initiatives:

  • โญ Starring the repository
  • ๐Ÿฆ Sharing on social media
  • ๐Ÿ’ฌ Telling your friends and colleagues
  • ๐Ÿค Contributing to the project

๐Ÿ“„ License

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

โญ Stargazers

๐Ÿด Forkers

Glowing Star Give us a Star and let's make magic! Glowing Star

Mirror Ball

๐Ÿ‘จโ€๐Ÿ’ป Built with โค๏ธ by AlgoVisualizer Team

โค๏ธ Rhythm and Contributors โค๏ธ

Open an Issue | ๐ŸŒŸ Star on GitHub | ๐Ÿš€ Live Demo

โฌ†๏ธ Back to Top

Ready to show off your coding achievements? Get started with AlgoVisualizer today! ๐Ÿš€

About

A web-based interactive platform for visualizing various data structures and algorithms, including sorting and searching techniques. Users can explore and understand the mechanics of algorithms through dynamic visual representations.

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 73.5%
  • CSS 26.4%
  • HTML 0.1%