Bzoj 3942——Censoring(KMP)

传送门

前面一大串的英文题面被我忽略了

KMP+栈

只需通过维护一个栈就可以了(* ̄︶ ̄)(我懒得多写)

 1 #include<cstdio>
 2 #include<iostream>
 3 #include<cmath>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<cstdlib>
 7 using namespace std;
 8 char s1[1000005],s2[1000005],s[1000005];
 9 int n,m,p[1000005],next[1000005],top;
10 int main()
11 {
12     gets(s1+1); gets(s2+1);
13     n=strlen(s1+1); m=strlen(s2+1);
14     p[1]=0; int j=0;
15     for (int i=1; i<=n; i++){
16         while (j>0 && s2[j+1]!=s2[i+1]) j=p[j];
17         if (s2[j+1]==s2[i+1]) j++;
18         p[i+1]=j;
19     }
20     next[0]=0;
21     for (int i=1; i<=n; i++){
22         s[++top]=s1[i];
23         int j=next[top-1];
24         while (j>0 && s2[j+1]!=s[top]) j=p[j];
25         if (s2[j+1]==s[top]) j++;
26         next[top]=j;
27         if (next[top]==m) top-=m;
28     }
29     for (int i=1; i<=top; i++) putchar(s[i]); putchar('\n');
30     return 0;
31 }

miao~~~

转载于:https://www.cnblogs.com/wangyh1008/p/9397170.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值