Skip to main content

A Pythonic indexed priority queue

Project description

A priority queue dictionary maps hashable objects (keys) to priority-determining values. It provides a hybrid dictionary/priority queue API.

Works with Python 2.7+, 3.4+, and PyPy.

CI Build State Documentation Status https://img.shields.io/pypi/v/pqdict.svg

The priority queue is implemented as a binary heap of (key, priority value) pairs, which supports:

  • O(1) search for the item with highest priority

  • O(log n) removal of the item with highest priority

  • O(log n) insertion of a new item

Additionally, an index maps elements to their location in the heap and is kept up to date as the heap is manipulated. As a result, pqdict also supports:

  • O(1) lookup of any item by key

  • O(log n) removal of any item

  • O(log n) updating of any item’s priority level

Documentation

Documentation is available at http://pqdict.readthedocs.org/en/latest/.

License

This module is released under the MIT license. The augmented heap implementation was adapted from the heapq module in the Python standard library, which was written by Kevin O’Connor and augmented by Tim Peters and Raymond Hettinger.

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

pqdict-1.0.1.tar.gz (82.6 kB view details)

Uploaded Source

Built Distribution

pqdict-1.0.1-py2.py3-none-any.whl (7.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pqdict-1.0.1.tar.gz.

File metadata

  • Download URL: pqdict-1.0.1.tar.gz
  • Upload date:
  • Size: 82.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.6

File hashes

Hashes for pqdict-1.0.1.tar.gz
Algorithm Hash digest
SHA256 b65ca80f42c2c2ffe2e9dc5729edc6c22b0367a313a8b856c3795b4360235110
MD5 7662496dedfa43939efecd4ae6dd1586
BLAKE2b-256 bc3ab1d4fc35876e1cb92f6f2f3bf7487bce24b44c2d7c0f44559ec584c8a277

See more details on using hashes here.

File details

Details for the file pqdict-1.0.1-py2.py3-none-any.whl.

File metadata

  • Download URL: pqdict-1.0.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.6

File hashes

Hashes for pqdict-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d81ac4c3af50e36ad3c85e7bab5dc99461616a46085db9077c676a159d365c7e
MD5 cb72c97092eb50632df8d460bc86e18b
BLAKE2b-256 b786638ec5b96dfa8993d6aa29a98a6bbcc5db872791c54ea76e6b04e506b6a3

See more details on using hashes here.

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