Balancing Run-Length Straight-Line Programs*

06/27/2022
by   Gonzalo Navarro, et al.
0

It was recently proved that any SLP generating a given string w can be transformed in linear time into an equivalent balanced SLP of the same asymptotic size. We show that this result also holds for RLSLPs, which are SLPs extended with run-length rules of the form A → B^t for t>2, deriving (A) = (B)^t. An immediate consequence is the simplification of the algorithm for extracting substrings of an RLSLP-compressed string. We also show that several problems like answering RMQs and computing Karp-Rabin fingerprints on substrings can be solved in 𝒪(g_rl) space and 𝒪(log n) time, g_rl being the size of the smallest RLSLP generating the string, of length n. We extend the result to solving more general operations on string ranges, in 𝒪(g_rl) space and 𝒪(log n) applications of the operation. In general, the smallest RLSLP can be asymptotically smaller than the smallest SLP by up to an 𝒪(log n) factor, so our results can make a difference in terms of the space needed for computing these operations efficiently for some string families.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset