Sparse Suffix and LCP Array: Simple, Direct, Small, and Fast

Lorraine A.K. Ayad, Grigorios Loukidis, Solon P. Pissis, Hilde Verbeek

Research output: Chapter in Book/Report/Conference proceedingConference paperpeer-review

45 Downloads (Pure)

Abstract

Sparse suffix sorting is the problem of sorting b = o(n) suffixes of a string of length n. Efficient sparse suffix sorting algorithms have existed for more than a decade. Despite the multitude of works and their justified claims for applications in text indexing, the existing algorithms have not been employed by practitioners. Arguably this is because there are no simple, direct, and efficient algorithms for sparse suffix array construction. We provide two new algorithms for constructing the sparse suffix and LCP arrays that are simultaneously simple, direct, small, and fast. In particular, our algorithms are: simple in the sense that they can be implemented using only basic data structures; direct in the sense that the output arrays are not a byproduct of constructing the sparse suffix tree or an LCE data structure; fast in the sense that they run in O(n log b) time, in the worst case, or in O(n) time, when the total number of suffixes with an LCP value greater than 2⌊log n/b⌋+1− 1 is in O(b/ log b), matching the time of optimal yet much more complicated algorithms [Gawrychowski and Kociumaka, SODA 2017; Birenzwige et al., SODA 2020]; and small in the sense that they can be implemented using only 8b + o(b) machine words. We also show that our second algorithm can be trivially amended to work in O(n) time for any uniformly random string. Our algorithms are non-trivial space-efficient adaptations of the Monte Carlo algorithm by I et al. for constructing the sparse suffix tree in O(n log b) time [STACS 2014].
Original languageEnglish
Title of host publicationLatin American Theoretical Informatics (LATIN) 2024
Publication statusAccepted/In press - 15 Dec 2023

Fingerprint

Dive into the research topics of 'Sparse Suffix and LCP Array: Simple, Direct, Small, and Fast'. Together they form a unique fingerprint.

Cite this