120 likes | 215 Views
Learn the Knuth-Morris-Pratt (KMP) algorithm over a binary alphabet. Build a Deterministic Finite Automaton (DFA) from a pattern and run the DFA on text for fast substring search. Follow step-by-step examples. Master the accept state to optimize performance.
E N D
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b
Knuth-Morris-Pratt • KMP algorithm. [over binary alphabet] • Build DFA from pattern. • Run DFA on text. Search Text a a a b a a b a a a b a a b a a a a a b a a a a a b a a a b a a a a a b a b 0 1 3 4 2 5 6 accept state b b b