GitPedia

Algorithms

A collection of algorithms and data structures

From williamfiset·Updated June 14, 2026·View on GitHub·

Algorithms and data structures are fundamental to efficient code and good software design. Creating and designing excellent algorithms is required for being an exemplary programmer. This repository's goal is to demonstrate how to correctly implement common data structures and algorithms in the simplest and most elegant ways. The project is written primarily in Java, distributed under the MIT License license, first published in 2017. It has gained significant community traction with 18,637 stars and 4,514 forks on GitHub. Key topics include: adjacency, adjacency-matrix, algorithm, algorithms, dijkstra.

License: MIT
Bazel Tests
README Checker
Sponsor

Algorithms & data structures project

Algorithms and data structures are fundamental to efficient code and good software design. Creating and designing excellent algorithms is required for being an exemplary programmer. This repository's goal is to demonstrate how to correctly implement common data structures and algorithms in the simplest and most elegant ways.

🎬 Many of the algorithms and data structures in this repo have companion video explanations on the William Fiset YouTube channel — so if the code alone doesn't click, grab some popcorn and watch the videos!

Running an algorithm implementation

To compile and run any of the algorithms here, you need at least JDK version 8 and Bazel

This project uses Bazel as its build system. Install Bazel by following the official installation guide.

Run a single algorithm like this:

bash
bazel run //src/main/java/com/williamfiset/algorithms/<subpackage>:<ClassName>

For instance:

bash
bazel run //src/main/java/com/williamfiset/algorithms/search:BinarySearch

Run all tests:

bash
bazel test //src/test/...

Run tests for a specific package:

bash
bazel test //src/test/java/com/williamfiset/algorithms/sorting:all

Compiling and running with only a JDK

If you don't want to use Bazel, you can compile and run with just the JDK:

Create a classes folder

bash
cd Algorithms mkdir classes

Compile the algorithm

bash
javac -sourcepath src/main/java -d classes src/main/java/<relative-path-to-java-source-file>

Run the algorithm

bash
java -cp classes <class-fully-qualified-name>

Example

bash
$ javac -d classes -sourcepath src/main/java src/main/java/com/williamfiset/algorithms/search/BinarySearch.java $ java -cp classes com.williamfiset.algorithms.search.BinarySearch

Data Structures

Dynamic Programming

Dynamic Programming Classics

Dynamic Programming Problem Examples

Adhoc

Tiling problems

Geometry

<details> <summary>More geometry algorithms</summary> </details>

Graph theory

Tree algorithms

Network flow

Main graph theory algorithms

Linear algebra

Mathematics

Other

Search algorithms

Sorting algorithms

String algorithms

License

This repository is released under the MIT license. In short, this means you are free to use this software in any personal, open-source or commercial projects. Attribution is optional but appreciated.

Sponsor

Consider sponsoring to support my creation of educational content:

Sponsor

Contributors

Showing top 12 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from williamfiset/algorithms via the GitHub API.Last fetched: 6/14/2026