Deprecated: $wgMWOAuthSharedUserIDs=false is deprecated, set $wgMWOAuthSharedUserIDs=true, $wgMWOAuthSharedUserSource='local' instead [Called from MediaWiki\HookContainer\HookContainer::run in /var/www/html/w/includes/HookContainer/HookContainer.php at line 135] in /var/www/html/w/includes/Debug/MWDebug.php on line 372
Developing new locality results for the Prüfer code using a remarkable linear-time decoding algorithm - MaRDI portal

Developing new locality results for the Prüfer code using a remarkable linear-time decoding algorithm (Q1010611)

From MaRDI portal





scientific article; zbMATH DE number 5540833
Language Label Description Also known as
English
Developing new locality results for the Prüfer code using a remarkable linear-time decoding algorithm
scientific article; zbMATH DE number 5540833

    Statements

    Developing new locality results for the Prüfer code using a remarkable linear-time decoding algorithm (English)
    0 references
    0 references
    0 references
    7 April 2009
    0 references
    Summary: The Prüfer Code is a bijection between the \(n^{n-2}\) trees on the vertex set \([1,n]\) and the \(n^{n-2}\) strings in the set \([1,n]^{n-2}\) (known as Prüfer strings of order \(n\)). Efficient linear-time algorithms for decoding (i.e., converting string to tree) and encoding (i.e., converting tree to string) are well-known. In this paper, we examine an improved decoding algorithm (due to Cho et al.) that scans the elements of the Prüfer string in reverse order, rather than in the usual forward direction. We show that the algorithm runs in linear time without requiring additional data strutures or sorting routines, and is an `online' algorithm --- every time a new string element is read, the algorithm can correctly output an additional tree edge without any knowledge of the future composition of the string. This new decoding algorithm allows us to derive results concerning the `locality' properties of the Prüfer Code (i.e., the effect of making small changes to a Prüfer string on the structure of the corresponding tree). First, we show that mutating the \(\mu\)th element of a Prüfer string (of any order) causes at most \(\mu + 1\) edge-changes in the corresponding tree. We also show that randomly mutating the first element of a random Prüfer string of order \(n\) causes two edge-changes in the corresponding tree with probability \(2(n-3)/n(n-1)\), and one edge-change otherwise. Then, based on computer-aided enumerations, we make three conjectures concerning the locality properties of the Prüfer Code, including a formula for the probability that a random mutation to the \(\mu\)th element of a random Prüfer string of order \(n\) causes exactly one edge-change in the corresponding tree. We show that if this formula is correct, then the probability that a random mutation to a random Prüfer string of order \(n\) causes exactly one edge-change in the corresponding tree is asymptotically equal to one-third, as \(n\) tends to infinity.
    0 references
    Prüfer code
    0 references
    linear time algorithms
    0 references
    decoding
    0 references
    string to tree
    0 references
    encoding
    0 references
    tree to string
    0 references
    decoding algorithm
    0 references
    random Prüfer stringrandom mutation
    0 references

    Identifiers