[复习]KMP 删除子串

来源:互联网 发布:利润率算法 编辑:程序博客网 时间:2024/06/03 20:21

题目背景
USACO 2015 FEBRUARY CONTEST,SILVER——PROBLEM 1 CENSORING

题目描述
给定一个字母串 S 和一个字母串 T ,所有字母都由小写字母 a..z 构成,S 和 T 的长度均不超过 1,000,000 ,T 的长度不会超过 S 。

从左往右枚举 S 串的每个字符,当枚举的一段连续字符串为 T ,则在 S 串中删掉这段连续字符串 T,后续字符依次向左移动填充删除的位置。然后在 S 中继续往右枚举,直到 S 串全部枚举完成为止。

请你输出最后的 S 串。

输入格式
输入的第一行是字符串 S ,第二行是字符串 T 。

输出格式
输出最后的 S 串。数据保证 S 串不会为空串。

样例数据
输入

whatthemomooofun
moo

输出

whatthefun

分析: 略有加强的KMP模板

代码:

#include<iostream>#include<cstdio>#include<cstdlib>#include<cstring>#include<string>#include<ctime>#include<cmath>#include<algorithm>#include<cctype>#include<iomanip>#include<queue>#include<set>using namespace std;char s[1000010],t[1000010],s1[1000010];int a[1000010],nxt[1000010];int lens,lent,lens1,cnt;int main(){    freopen("sczc.in","r",stdin);    freopen("sczc.out","w",stdout);    scanf("%s%s",s+1,t+1);    lens=strlen(s+1);    lent=strlen(t+1);    for(int i=2,j=0;i<=lent;++i)    {        while(j&&t[j+1]!=t[i])            j=nxt[j];        if(t[j+1]==t[i])            ++j;        nxt[i]=j;    }    for(int i=1,j=0;i<=lens;++i)    {        while(j&&t[j+1]!=s[i])            j=nxt[j];        if(t[j+1]==s[i])            ++j;        a[++cnt]=j;        s1[cnt]=s[i];//用新数组存下s方便匹配删除后更新        if(j==lent)        {            cnt=cnt-lent;//直接把s1的下标跳到cnt-lent(也就是删掉了一个t,因为会被后面的覆盖掉),在那个位置a记录了到那个点已经有多少个匹配的字符,直接从下一个字符开始继续匹配            j=a[cnt];        }    }    for(int i=1;i<=cnt;++i)        cout<<s1[i];    return 0;}

本题结。

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 日本语言学校申请研究生签证怎么办 在埃塞俄比亚签证过期了怎么办 看完的小说想要卖掉该怎么办 在俄罗斯脸干了痛怎么办 苹果手表电池放亏了怎么办 平板电脑电池不耐用怎么办 计算机电池放入后没反应怎么办 笔记本电脑玩游戏花屏怎么办 笔记本玩游戏花屏怎么办 笔记本电脑充电插口坏了怎么办 车蓄电池没电了怎么办 汤浅q85电瓶亏电怎么办 富士康自离行李怎么办 微店红酒食品认证怎么办 yy频道提示禁止游客进入怎么办 口红颜色太艳了怎么办 我在菲律宾想走怎么办 当国家流通货币不够用怎么办 苹果5s账号密码忘记怎么办 钢铁雄心3补给不足怎么办 灯外观颜色太难看了怎么办 被移民公司骗了怎么办 文明5大包锁区怎么办 鸭子被黄鼠狼叼走了怎么办 黄鼠狼再店了拉屎怎么办 我只有信用卡但是又想去嫖怎么办 瑞士退税单掉了怎么办 装了新风噪音大怎么办 意大利 护照被偷了怎么办 请问去意大利要怎么办护照 在意大利护照丢了怎么办 考研二战档案打回原籍怎么办 脸上的肉往下掉怎么办 眼镜带了往下掉怎么办 孩子捅别的孩子眼睛了怎么办 眼睛不小心捅伤怎么办 我的爸爸是小偷怎么办 违停罚款忘记交怎么办 顺风车无人接单怎么办 来例假腰特别疼怎么办 把人撞死了全责怎么办