Misplaced Pages

Radix heap

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
This article includes a list of general references, but it lacks sufficient corresponding inline citations. Please help to improve this article by introducing more precise citations. (September 2017) (Learn how and when to remove this message)
This article relies largely or entirely on a single source. Relevant discussion may be found on the talk page. Please help improve this article by introducing citations to additional sources.
Find sources: "Radix heap" – news · newspapers · books · scholar · JSTOR (May 2024)

A radix heap is a data structure for realizing the operations of a monotone priority queue. A set of elements to which a key is assigned can then be managed. The run time of the operations depends on the difference between the largest and smallest key or constant. The data structure consists mainly of a series of buckets, the size of which increases exponentially.

Prerequisites

  1. all keys are natural numbers;
  2. max. key - min. key {\displaystyle \leq } C for constant C;
  3. the extract-min operation is monotonic; that is, the values returned by successive extract-min calls are monotonically increasing.

Description of data structure

The three most important fields are:

  1. b {\displaystyle b} of size B := l o g ( C + 1 ) + 1 {\displaystyle B:=\lfloor log(C+1)\rfloor +1} , with 0 as the lowest index, stores the buckets;
  2. u {\displaystyle u} of size B + 1 {\displaystyle B+1} , with 0 as the lowest index, store the (lower) bounds of the buckets;
  3. b N u m {\displaystyle bNum} , holds for each element x {\displaystyle x} in the heap the bucket in which it is stored.

The above diagram shows the data structure. The following invariants apply:

  1. u [ i ] {\displaystyle u\leq } key in b [ i ] < u [ i + 1 ] {\displaystyle b<u} : the keys in b [ i ] {\displaystyle b} are up or down through the value in u [ i + 1 ] {\displaystyle u} or u [ i ] {\displaystyle u} limited.
  2. u [ 0 ] = 0 , u [ 1 ] = u [ 0 ] + 1 , u [ B ] = {\displaystyle u=0,u=u+1,u=\infty } and 0 u [ i + 1 ] u [ i ] 2 i 1 {\displaystyle 0\leq u-u\leq 2^{i-1}} for i = 1 , , B 1 {\displaystyle i=1,\ldots ,B-1} : the sizes of the buckets increase exponentially.

It is important to note the exponential growth of the limits (and thus the range that a bucket holds). In this way the logarithmic dependence of the field quantities is of value C, the maximum difference between two key values.

Operations

During initialization, empty buckets are generated and the lower bounds u {\displaystyle u} are generated (according to invariant 2); running time O ( B ) {\displaystyle O(B)} .

During insert, a new element x {\displaystyle x} is linearly moved from right to left through the buckets and the new element with k ( x ) {\displaystyle k(x)} is stored in the left bucket to that u [ i ] k ( x ) {\displaystyle u\geq k(x)} ; running time O ( B ) {\displaystyle O(B)} .

For decrease-key, first the key value is decreased (checking for compliance with the invariants). Then, the b N u m {\displaystyle bNum} field is used to locate the element and it is iterated to the left, if necessary, analogously to the insert operation. The running time is O ( 1 ) {\displaystyle O(1)} (amortized).

The extract-min operation removes an element from bucket b [ 0 ] {\displaystyle b} and returns it. If the bucket b [ 0 ] {\displaystyle b} is not yet empty, the operation is terminated. If, however, it is empty, the next larger non-empty bucket is searched, its smallest element k {\displaystyle k} tracked and u [ 0 ] {\displaystyle u} is set to k (monotonicity is required for this). Then, according to the invariants, the bucket boundaries are redefined and the elements removed b [ i ] {\displaystyle b} to the newly formed buckets; running time O ( 1 ) {\displaystyle O(1)} (amortized).

If displayed, the field b N u m {\displaystyle bNum} is updated.

References

Category:
Radix heap Add topic