More Efficient Bottom-up Multi-pattern Matching in Trees
Abstract
Pattern matching in trees is fundamental to a variety of programming language systems. However, progress has been slow in satisfying a pressing need for general-purpose pattern-matching algorithms that are efficient in both time and space. We offer asymptotic improvements in both time and space to Chase's bottom-up algorithm for pattern preprocessing. A preliminary implementation of our algorithm runs ten times faster than Chase's (1987) implementation on the hardest problem instances. Our preprocessing algorithm has the advantage of being on-line with respect to pattern additions and deletions. It also adapts to favorable input instances, and on Hoffmann and O'Donnell's (1982) class of simple patterns, it performs better than their special-purpose algorithm tailored to this class. We show how to modify our algorithm using a new decomposition method to obtain a space/time tradeoff. Finally, we trade a log factor in time for a linear space bottom-up pattern-matching algorithm that handles a wide subclass of Hoffmann and O'Donnell's (1982) simple patterns.
Recommended Citation
J. Cai et al., "More Efficient Bottom-up Multi-pattern Matching in Trees," Theoretical Computer Science, Elsevier, Jan 1992.
The definitive version is available at https://doi.org/10.1016/0304-3975(92)90277-M
Department(s)
Mathematics and Statistics
International Standard Serial Number (ISSN)
0304-3975
Document Type
Article - Journal
Document Version
Citation
File Type
text
Language(s)
English
Rights
© 1992 Elsevier, All rights reserved.
Publication Date
01 Jan 1992