本来以为是很高级的算法 其实理解以后并不难 只是在字典树的基础上用fail数组标记一下回朔的位置 加速查找 就可以实现多模式串的匹配查找
模版如下:
#include #include #include #include #include #include #include #include #include #include #include #include #include #include
q; fail[root]=root; for(int i=0;i<26;i++){ if(trie[root][i]==-1) trie[root][i]=root; else{ fail[trie[root][i]]=root; q.push(trie[root][i]); } } while(!q.empty()){ int now=q.front(); q.pop(); for(int i=0;i<26;i++){ if(trie[now][i]==-1) trie[now][i]=trie[fail[now]][i]; else{ fail[trie[now][i]]=trie[fail[now]][i]; q.push(trie[now][i]); } } } } int query(string s){ //查询操作 int len=s.length(); int now=root; int res=0; for(int i=0;i