好久没写kmp都不会写了……

开两个栈,s存当前串,c存匹配位置

用t串在栈s上匹配,栈每次入栈一个原串字符,用t串匹配一下,如果栈s末尾匹配了t则弹栈

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=1000005;
int n,m,c[N],top,ne[N];
char a[N],b[N],s[N];
void gtnxt()
{
ne[0]=-1;
for(int i=1,j=-1;i<n;i++)
{
while(j!=-1&&b[i]!=b[j+1])
j=ne[j];
if(b[i]==b[j+1])
j++;
ne[i]=j;
}
}
int main()
{
scanf("%s%s",a,b);
n=strlen(a),m=strlen(b);
gtnxt();
for(int i=0;i<n;i++)
{
int j=c[top];
s[++top]=a[i];
while(j!=-1&&b[j+1]!=s[top])
j=ne[j];
if(b[j+1]==s[top])
j++;
c[top]=j;
if(c[top]==m-1)
top-=m;
}
s[top+1]='\0';
puts(s+1);
return 0;
}

最新文章

  1. Nginx概念及基础安装--详细讲解
  2. 使用discovery板上的st-link给别的板子下载
  3. VS调试时下不到断点的处理方式。
  4. 黑马程序员——HTML表格布局
  5. ASP.NET本质论第一章网站应用程序学习笔记2
  6. Object-C 基础笔记2--方法
  7. TP复习
  8. PHP学习笔记 - 入门篇(4)
  9. ZOJ 3329 One Person Game 【概率DP,求期望】
  10. How to write a probeContentType() and Usage?
  11. centos 7 安装MySQL 5.6
  12. Linux使用Public Key方式远程登录
  13. 【Python】模拟radius coa报文
  14. Storage 001 电商数据库设计
  15. 全民https时代,Let&#39;s Encrypt免费SSL证书的申请及使用(Tomcat版)
  16. Linux 磁盘介绍(磁盘、分区、MBR、GPT)
  17. 人人中的 shiro权限管理 简单说明
  18. pandas实现excel中的数据透视表和Vlookup函数功能
  19. 【Dubbo&amp;&amp;Zookeeper】1、Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)
  20. Codeforces Round #281 (Div. 2) B. Vasya and Wrestling 水题

热门文章

  1. Jquery 引擎模板 -template详解
  2. Selenium IDE-自动化实战
  3. [luoguP1494] 岳麓山上打水 &amp;&amp; [luoguP2744] [USACO5.3]量取牛奶Milk Measuring
  4. IDA-IDC脚本编写语法
  5. node的express框架,核心第三方模块body-parser 获取我们所有post请求传过来数据
  6. PHP $_SERVER的使用
  7. Oracle锁表数据查询及解决方法
  8. Max Num
  9. 谈谈控制器技术SpringMVC与struts2
  10. 洛谷 P3984 高兴的津津