c++设计模式之抽象工厂
572 2023-04-03 05:04:26
题面
本来就是个裸的KMP,但是这个题是有删除的,所以可以维护一个栈,每次的 \(j\) 都继承栈顶元素的 \(j\),然后如果找到了一个匹配,就直接弹栈即可。因为只会进栈 \(O(n)\) 次,所以总复杂度也是 \(O(n)\) 的。这个题算是栈的妙用了。
#include<iostream>#include<cstdio>#include<cstring>#include<stack>using namespace std;const int N=1e6+13;char s[N],t[N];bool vis[N];int n,m,nxt[N],pos[N];inline void init(){nxt[1]=0;for(int i=2,j=0;i<=m;++i){while(j&&t[j+1]!=t[i]) j=nxt[j];if(t[j+1]==t[i]) ++j;nxt[i]=j;}}inline void KMP(){stack<int> st;st.push(0);for(int i=1;i<=n;++i){int j=pos[st.top()];while(j&&t[j+1]!=s[i]) j=nxt[j];if(t[j+1]==s[i]) ++j;if(j==m){vis[i]=1,--j;while(j--) vis[st.top()]=1,st.pop();}else st.push(i),pos[i]=j;}}int main(){scanf("%s%s",s+1,t+1);n=strlen(s+1),m=strlen(t+1);init();KMP();for(int i=1;i<=n;++i)if(!vis[i]) printf("%c",s[i]);return 0;}