Go to file
Andrew Grangaard f36ee034f1
[mypy] Annotate other/lru_cache and other/lfu_cache (#5755)
* Adds repr and doctest of current behavior linkedlist in other/lru_cache

* Blocks removal of head or tail of double linked list

* clarifies add() logic for double linked list in other/lru_cache

* expands doctests to compare cache and lru cache

* [mypy] annotates vars for other/lru_cache

* [mypy] Annotates lru_cache decorator for other/lru_cache

* Higher order functions require a verbose Callable annotation

* [mypy] Makes LRU_Cache generic over key and value types for other/lru_cache

+ no reason to force int -> int

* [mypy] makes decorator a classmethod for access to class generic types

* breaks two long lines in doctest for other/lru_cache

* simplifies boundary test remove() for other/lru_cache

* [mypy] Annotates, adds doctests, and makes Generic other/lfu_cache

See also commits to other/lru_cache which guided these

* [mypy] annotates cls var in other/lfu_cache

* cleans up items from code review for lfu_cache and lru_cache

* [mypy] runs mypy on lfu_cache and lru_cache
2021-11-10 23:21:16 +01:00
.github mypy: Exclude only 20 files that are still failing (#5608) 2021-11-06 13:58:15 +01:00
arithmetic_analysis Add Jacobi Iteration Method (#5113) 2021-11-09 22:40:57 +08:00
audio_filters Add README files 1/7 (#5754) 2021-11-04 18:49:36 +08:00
backtracking Add README files 1/7 (#5754) 2021-11-04 18:49:36 +08:00
bit_manipulation Add README files 1/7 (#5754) 2021-11-04 18:49:36 +08:00
blockchain Pyupgrade to Python 3.9 (#4718) 2021-09-07 13:37:03 +02:00
boolean_algebra Add README files 1/7 (#5754) 2021-11-04 18:49:36 +08:00
cellular_automata add implementation of Nagel and Schrekenberg algo (#5584) 2021-10-26 09:57:49 +02:00
ciphers Split base85.py into functions, Add doctests (#5746) 2021-11-02 11:10:25 +01:00
compression [mypy] annotate compression (#5570) 2021-10-26 12:29:27 +02:00
computer_vision ADD the algorithms of image augmentation (#5792) 2021-11-08 06:35:40 +01:00
conversions Add stone unit of measuring weight (#5730) 2021-11-02 00:09:40 +01:00
data_structures [mypy] Fix type annotations in data_structures/stacks/next_greater_element.py (#5763) 2021-11-05 20:45:37 +01:00
digital_image_processing Add gabor filter (#5289) 2021-11-02 18:06:39 +08:00
divide_and_conquer Remove unnecessary branch (#4824) 2021-10-12 00:33:06 +08:00
dynamic_programming Add all_construct dynamic programming implementation (#5626) 2021-11-04 16:18:38 +01:00
electronics Add implementation of Coulomb's Law (#4897) 2021-10-22 11:52:39 +08:00
file_transfer [mypy] fix small folders (#4292) 2021-03-23 16:51:50 +01:00
financial Add equated_monthly_installments.py in Financials (#5775) 2021-11-07 15:40:23 +01:00
fractals mandelbrot.py: Commenting out long running tests (#5558) 2021-10-23 18:15:30 +02:00
fuzzy_logic Improve Project Euler problem 014 solution 2 (#5744) 2021-11-04 17:01:21 +01:00
genetic_algorithm Add __init__.py files in all the directories (#2503) 2020-09-28 19:42:36 +02:00
geodesy Fix imports for all namespace packages (#2506) 2020-09-28 23:41:04 +02:00
graphics New fractals folder (#4277) 2021-03-20 06:49:30 +01:00
graphs [mypy] Type annotations for graphs directory (#5798) 2021-11-08 19:18:30 +01:00
greedy_methods Added Optimal Merge Pattern Algorithm (#5274) 2021-10-14 12:51:13 +02:00
hashes Implementation of SHA-256 using Python (#5532) 2021-10-23 15:20:52 +02:00
knapsack Rewrite parts of Vector and Matrix (#5362) 2021-10-27 11:48:43 +08:00
linear_algebra Deduplicate euclidean_length method in Vector (#5658) 2021-10-31 22:16:02 +08:00
machine_learning Local Weighted Learning (#5615) 2021-10-31 12:27:50 +01:00
maths [mypy] Fix type annotations for maths directory (#5782) 2021-11-07 16:13:58 +01:00
matrix [mypy] Fix matrix_operation.py (#5808) 2021-11-10 16:22:52 +01:00
networking_flow Add __init__.py files in all the directories (#2503) 2020-09-28 19:42:36 +02:00
neural_network [mypy] fix small folders 2 (#4293) 2021-03-26 12:21:16 +01:00
other [mypy] Annotate other/lru_cache and other/lfu_cache (#5755) 2021-11-10 23:21:16 +01:00
physics Added newtons_second_law_of_motion.py (#5474) 2021-11-04 18:48:57 +08:00
project_euler Add solution for Project Euler problem 145 (#5173) 2021-11-10 18:22:27 +08:00
quantum Approve functions used as default arguments (#4699) 2021-08-31 07:56:19 +02:00
scheduling fix typo on line 126 (#5768) 2021-11-05 06:06:37 +01:00
scripts Wavelet tree (#4267) 2021-06-08 22:49:33 +02:00
searches [mypy] Type annotations for searches directory (#5799) 2021-11-09 16:48:30 +01:00
sorts fix: use += in sorts/recursive_mergesort_array.py (#5019) 2021-10-27 00:43:46 +08:00
strings edited strings/anagram.py (#5770) 2021-11-08 18:58:15 +01:00
web_programming Added reddit.py to get data from reddit (#5698) 2021-11-04 16:36:22 +01:00
.coveragerc Add pytest-cov (#1578) 2019-11-17 19:37:58 +01:00
.gitattributes Create .gitattributes for Cross OS compatibility (#3410) 2020-10-17 07:25:25 +02:00
.gitignore contribution guidelines checks (#1787) 2020-03-04 13:40:28 +01:00
.gitpod.yml Change gitpod configuration for python3. (#1827) 2020-04-07 12:20:08 +02:00
.pre-commit-config.yaml Add pyupgrade to pre-commit (#5638) 2021-10-28 16:45:59 +02:00
CONTRIBUTING.md Replace Travis CI mentions with GitHub actions (#5751) 2021-11-02 22:28:09 +01:00
DIRECTORY.md [mypy] Fix matrix_operation.py (#5808) 2021-11-10 16:22:52 +01:00
LICENSE.md Update LICENSE.md (#4210) 2021-02-19 19:15:19 +01:00
mypy.ini [mypy] Annotate other/lru_cache and other/lfu_cache (#5755) 2021-11-10 23:21:16 +01:00
pytest.ini Move validate_solutions and add durations flag to pytest.ini (#3704) 2020-10-24 19:07:33 +05:30
README.md docs: renovate README (#4620) 2021-09-29 23:34:35 +05:30
requirements.txt Improve Project Euler problem 014 solution 2 (#5744) 2021-11-04 17:01:21 +01:00

The Algorithms - Python

Gitpod Ready-to-Code Contributions Welcome Donate Discord chat Gitter chat
GitHub Workflow Status LGTM pre-commit code style: black

All algorithms implemented in Python - for education

Implementations are for learning purposes only. As they may be less efficient than the implementations in the Python standard library, use them at your discretion.

Getting Started

Read through our Contribution Guidelines before you contribute.

Community Channels

We're on Discord and Gitter! Community channels are great for you to ask questions and get help. Please join us!

List of Algorithms

See our directory for easier navigation and better overview of the project.