Skip to main content

You should solve DSA problems efficiently.

Project description

LeetPy Banner

Debugging is twice as hard as writing the code in the first place.

If you solve problems related to Data Structures & Algorithms (DSA), you know how frustrating it is to debug complex data structures like Binary Trees and Directed Graphs.

LeetPy is a lightweight Python package that makes you more efficient when you solve DSA problems. It contains utility functions and algorithms that make debugging and testing SO MUCH easier. Here are some features:

  • Several Data Structures: Binary Trees, Linked Lists, 2-D Arrays, etc.
  • Visualize Your Objects: LeetPy provides convenient print() functions that show you what your structure looks like (all inside your terminal!).
  • Save & Export: Serialization and export functions help you save an exact copy of your structure, and give you the code to generate them from scratch.
  • Flexibility: Create your data structure however you want; LeetPy's algorithms will always work correctly.

Installation

To install the latest stable release, run:

$ pip install leetpy

To install from the latest GitHub commit:

pip install git+https://github.com/aryanpingle/leetpy

Usage & Examples

Here's a minimal use-case:

# Create a random binary tree and visualize it

from leetpy import BinaryTree

root = BinaryTree.create(n=20)  # create a random binary tree with 20 nodes
BinaryTree.print_structure(root)  # visualize the binary tree

And here's a complex one:

# Suppose you want to 'save' 10 binary search trees (example: for testing purposes)
# You would need some Python code that generates each tree exactly

from leetpy import BinaryTree

for i in range(1, 11):
    # Generate a random binary search tree (BST) with 20 nodes
    # Each node should have a value between 1 and 10 (inclusive)
    root = BinaryTree.create(n=20, min_val=1, max_val=10, make_bst=True)
    
    # Get the python code that generates this exact BST
    # Oh, and make each node an object of class "CustomNode"
    # Oh, and keep indentation to 2 spaces
    code += "\n" + BinaryTree.export_as_code(root, node_alias="CustomNode", indent=2)

with open("testing.py", "w") as f:
    f.write(code)

LeetPy offers a wide range of utility functions - for a wide range of data structures. Here's a comprehensive list of examples:

Example Description
Binary Tree Example 1 Create a randomized binary tree with 20 nodes and visualize it.
Binary Tree Example 2 Generate a file which contains code for creating randomized binary trees with some constraints (without dependending on the leetpy package).
Binary Tree Example 3 Same as example 2, but with inlined generated code (reducing the number of generated lines).
Linked List Example 1 Create a randomized singly linked list with 20 nodes and visualize it.
Linked List Example 2 Create a randomized AND CYCLIC singly linked list with 20 UNIQUE nodes and visualize it.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

leetpy-0.2.1.tar.gz (15.5 kB view hashes)

Uploaded Source

Built Distribution

leetpy-0.2.1-py3-none-any.whl (17.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page