bzoj 3942: [Usaco2015 Feb]Censoring【kmp+栈】
2024-08-30 20:23:26
好久没写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;
}
最新文章
- Nginx概念及基础安装--详细讲解
- 使用discovery板上的st-link给别的板子下载
- VS调试时下不到断点的处理方式。
- 黑马程序员——HTML表格布局
- ASP.NET本质论第一章网站应用程序学习笔记2
- Object-C 基础笔记2--方法
- TP复习
- PHP学习笔记 - 入门篇(4)
- ZOJ 3329 One Person Game 【概率DP,求期望】
- How to write a probeContentType() and Usage?
- centos 7 安装MySQL 5.6
- Linux使用Public Key方式远程登录
- 【Python】模拟radius coa报文
- Storage 001 电商数据库设计
- 全民https时代,Let&#39;s Encrypt免费SSL证书的申请及使用(Tomcat版)
- Linux 磁盘介绍(磁盘、分区、MBR、GPT)
- 人人中的 shiro权限管理 简单说明
- pandas实现excel中的数据透视表和Vlookup函数功能
- 【Dubbo&;&;Zookeeper】1、Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)
- Codeforces Round #281 (Div. 2) B. Vasya and Wrestling 水题
热门文章
- Jquery 引擎模板 -template详解
- Selenium IDE-自动化实战
- [luoguP1494] 岳麓山上打水 &;&; [luoguP2744] [USACO5.3]量取牛奶Milk Measuring
- IDA-IDC脚本编写语法
- node的express框架,核心第三方模块body-parser 获取我们所有post请求传过来数据
- PHP $_SERVER的使用
- Oracle锁表数据查询及解决方法
- Max Num
- 谈谈控制器技术SpringMVC与struts2
- 洛谷 P3984 高兴的津津