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.1.0.tar.gz (83.9 kB view details)

Uploaded Source

Built Distribution

pqdict-1.1.0-py2.py3-none-any.whl (7.6 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: pqdict-1.1.0.tar.gz
  • Upload date:
  • Size: 83.9 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.1.0.tar.gz
Algorithm Hash digest
SHA256 13ac66cf1095c6b87bb89720b1b8c6b94195b2c5d0702dd82e969226b412a0b7
MD5 fa0f26c66a2988bad485c010aef27478
BLAKE2b-256 f1eff1185c7ae07692a32af1382acb5c9714ba50c1fa0a6914cf0e40748a094f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pqdict-1.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 7.6 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.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 fa7283c892f7ab9357e7c6bb58f11e94d6db3713c1ad35b3780ab6a20b4b0f6d
MD5 a3cb4361167a7378075a4cfdf3f246cb
BLAKE2b-256 ae0ce1e57783f4d3b027c546df0dbaacbdbc92a84b59560b95020da5c75f604e

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