zoukankan      html  css  js  c++  java
  • Censoring(栈+KMP)

    # 10048. 「一本通 2.2 练习 4」Censoring

    【题目描述】

    给出两个字符串 $S$ 和 $T$,每次从前往后找到 $S$ 的一个子串 $A=T$ 并将其删除,空缺位依次向前补齐,重复上述操作多次,直到 $S$ 串中不含 $T$ 串。输出最终的 $S$ 串。

    【算法】

    1、kmp $O(n)$就可以定位。
    2、栈是个好东西啊。
    注:一开始想双指针,实在不好写。。。栈很好,它可以弹出去。。。(此处滑稽脸)

    【代码】

    #include <bits/stdc++.h>
    using namespace std;
    int l1,l2,top;
    int nxt[1000100],f[1000100];
    char s[1000100],t[1000100],ans[1000100];
    void parse() {
        nxt[1]=0;
        for(int i=2,j=0;i<=l2;i++) {
            while(j>0&&(j==l2||t[i]!=t[j+1])) j=nxt[j];
            if(t[i]==t[j+1]) j++;
            nxt[i]=j;
        }
    }
    int main() {
        scanf("%s%s",s+1,t+1);
        l1=strlen(s+1),l2=strlen(t+1);
        parse();
        for(int i=1,j=0;i<=l1;i++) {
            ans[++top]=s[i];
            while(j>0&&(j==l2||s[i]!=t[j+1])) j=nxt[j];
            if(s[i]==t[j+1]) j++;
            f[top]=j;
            if(j==l2) {
                top-=l2;
                j=f[top];
            }
        }
        ans[++top]='';
        printf("%s
    ",ans+1);
        return 0;
    }
    
    
  • 相关阅读:
    iBatis,第二次亲密接触
    微斯人,吾谁与归
    一个月了
    生命在于运动
    眼皮跳了好几天
    往返
    中病毒,学习批处理

    爱如潮水
    今天夏至
  • 原文地址:https://www.cnblogs.com/Willendless/p/9610642.html
Copyright © 2011-2022 走看看