The classic string indexing problem is to preprocess a string S into a compact data structure that supports efficient pattern matching queries. Typical queries include existential queries (decide if the pattern occurs in S), reporting queries (return all positions where the pattern occurs), and counting queries (return the number of occurrences of the pattern). In this paper we consider a variant of string indexing, where the goal is to compactly represent the string such that given two patterns P1 and P2 and a gap range [α, β] we can quickly find the consecutive occurrences of P1 and P2 with distance in [α, β], i.e., pairs of subsequent occurrences with distance within the range. We present data structures that use eO(n) space and query time eO(|P1| + |P2| + n2/3) for existence and counting and Õ(|P1| + |P2| + n2/3occ1/3) for reporting. We complement this with a conditional lower bound based on the set intersection problem showing that any solution using eO(n) space must use Ω(|P1| + |P2| + √n) query time. To obtain our results we develop new techniques and ideas of independent interest including a new suffix tree decomposition and hardness of a variant of the set intersection problem.
|Journal||Leibniz International Proceedings in Informatics|
|Publication status||Published - 2021|
- Conditional lower bound
- Consecutive occurrences
- String indexing
- Two patterns