| Article ID | Journal | Published Year | Pages | File Type | 
|---|---|---|---|---|
| 430873 | Journal of Discrete Algorithms | 2014 | 8 Pages | 
We consider a natural variant of the classical multiple pattern matching problem: given a Lempel–Ziv–Welch representation of a string and a collection of (uncompressed) patterns, does any of them occur in the text?As shown by Kida et al. [15], extending the single pattern algorithm of Amir, Benson and Farach [2] gives a running time of O(n+M2)O(n+M2) for the more general case, where n is the number of codewords in the compressed representation of the text and M is the sum of the length of all patterns. We prove that in fact it is possible to achieve O(nlogM+M) or O(n+M1+ϵ)O(n+M1+ϵ) complexity. While not linear, running times of our solutions match the single pattern bounds achieved by the previously known solutions [2] and [17] in a more structured and unified manner, and without using any combinatorics on words. The only nontrivial components of our method are suffix arrays, constant time range minimum queries, and balanced binary search trees.
