A collection of graph algorithms implemented in Rust. This repository aims to provide efficient and easy-to-understand implementations of various graph algorithms for educational purposes and practical use.
Contributions are welcome to expand the set of algorithms and improve existing implementations.
A* is a pathfinding and graph traversal algorithm that is often used in many fields of computer science due to its completeness, optimality, and optimal efficiency.
BFS explores the graph level by level, starting from a given node. It is used for finding the shortest path in an unweighted graph.
DFS explores as far as possible along each branch before backtracking. It is used for pathfinding and topological sorting.
This crate uses #![forbid(unsafe_code)]
to ensure everything is implemented in 100% safe Rust.
The examples
directory contains example implementations of various graph algorithms:
use graph_algorithms::{DijkstraAlgorithm, GraphAlgorithm};
This crate provides optional features for different algorithms.
By default, all features are enabled. You can customize the features when adding the dependency in your Cargo.toml
:
[dependencies]
graph-algorithms-rs = { version = "x.x.x", default-features = false, features = ["dijkstra"] }
For a detailed list of available algorithms, refer to the Reference implementation section.
Build the application:
cargo build
Test the application:
cargo test
Run clippy:
cargo clippy --all-targets --all-features --no-deps -- -D warnings
Run lint:
cargo fmt
Generate documentation in HTML format:
cargo doc --open