Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nbro/andz
Algorithms and data structures for educational, demonstrational and experimental purposes.
https://github.com/nbro/andz
algorithms computer-science data-structures demonstration education experimental python research software-engineering unit-testing
Last synced: about 1 month ago
JSON representation
Algorithms and data structures for educational, demonstrational and experimental purposes.
- Host: GitHub
- URL: https://github.com/nbro/andz
- Owner: nbro
- License: mit
- Created: 2015-12-21T17:01:55.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-03-24T18:27:53.000Z (10 months ago)
- Last Synced: 2024-05-21T00:59:05.164Z (8 months ago)
- Topics: algorithms, computer-science, data-structures, demonstration, education, experimental, python, research, software-engineering, unit-testing
- Language: Python
- Homepage:
- Size: 34.7 MB
- Stars: 54
- Watchers: 7
- Forks: 12
- Open Issues: 45
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Algorithms and Data Structures (andz)
[![Python 3.9+](https://img.shields.io/badge/python-3.9+-blue.svg)](https://www.python.org/downloads/)
[![](https://img.shields.io/badge/stability-experimental-red.svg)](http://www.engr.sjsu.edu/fayad/SoftwareStability/)
[![Packagist](https://img.shields.io/packagist/l/doctrine/orm.svg?maxAge=2592000)](./LICENSE.md)
[![Tests](https://github.com/nbro/andz/actions/workflows/tests.yml/badge.svg)](https://github.com/nbro/andz/actions/workflows/tests.yml)## Introduction
`andz` stands for **a**lgorithms a**n**d **d**ata structure**z**.
> The `s` was replaced with `z` because
> there was already a dummy package called `ands` on PyPI.In this package, you can find some of the most common algorithms and
data structures studied in Computer Science,
such as quick-sort or binary-search trees.
The algorithms are divided into main categories,
such as sorting algorithms or dynamic programming algorithms, but note that
some algorithms and DS can fall into multiple categories .> The current main goal of this project is for me to learn more about
new algorithms and data structures, but I hope these implementations
can also be useful to anyone interested in them.## Development
I use
- [poetry](https://python-poetry.org/) for development
- the [`Makefile`](./Makefile) to declare common commands
- [`pyenv`](https://github.com/pyenv/pyenv) to manage different Python versions locally
- GitHub Actions for CI/CDFor more info about how to develop,
see [`./docs/how_to_develop.md`](docs/how_to_develop.md).## How to install?
```
pip install andz
```## Documentation
Most modules and functions have been thoroughly documented,
so the best way to learn about the algorithms and data structures is
to read the source code and the related docstrings and comments.You can find more documentation under [`docs`](./docs).
There you will find the history of the project,
development conventions that should be adapted, etc.