刷题总结——字符串(ssoj)
题目:
给定n个小的字符串T和一个大的字符串S,先输出T总共再S中出现了多少次
然后q个询问···每次修改S上的一个字母,然后再次输出上述答案···
n小于1000,q<200000,T的总长度和S的长度都小于100000;
题解:
我们可以发现,每次修改位置P,那么S影响的范围只有在P-MAX到P+MAX的范围,其中MAX为T的最长长度····所以将这一范围的S跑一边AC自动机··然后更新答案即可··
这道题也让我发现我做AC自动机以来一直有的一个不好的习惯··每次求出现次数都是暴力跳fail指针,这样再这道题里直接T····
其实再我们bfs构建fail指针时,设u的指针为v,我们可以直接tree[u].cnt+=tree[v].cnt,这样每次加的时候直接加上一个节点cnt就可以了··不用暴力跳fail···代码:
代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
#include<queue>
using namespace std;
queue<int>que;
const int N=;
struct node
{
int son[],cnt,fail;
void clear()
{
memset(son,,sizeof(son));
cnt=fail=;
}
}tree[N];
int n,m,T,tot,maxx=;
char s[N],t[];
inline int R()
{
char c;int f=;
for(c=getchar();c<''||c>'';c=getchar());
for(;c<=''&&c>='';c=getchar()) f=(f<<)+(f<<)+c-'';
return f;
}
int buf[];
inline void W(int x){
if(!x){putchar('');return ;}
if(x<){putchar('-');x=-x;}
while(x) buf[++buf[]]=x%,x/=;
while(buf[]) putchar(buf[buf[]--]+);
return ;
} inline void build()
{
int po=;
int len=strlen(s);maxx=max(maxx,len);
for(int i=;i<len;i++)
{
if(!tree[po].son[s[i]-'a'])
tree[tree[po].son[s[i]-'a']=++tot].clear();
po=tree[po].son[s[i]-'a'];
}
tree[po].cnt++;
}
inline void buildfail()
{
que.push();
while(!que.empty())
{
int u=que.front();que.pop();
for(int i=;i<;i++)
{
int v=tree[u].fail;
while(!tree[v].son[i]) v=tree[v].fail;
v=tree[v].son[i];int w=tree[u].son[i];
if(w) tree[w].fail=v,que.push(w),tree[w].cnt+=tree[v].cnt;
else tree[u].son[i]=v;
}
}
}
int main()
{
//freopen("string.in","r",stdin);
//freopen("string.out","w",stdout);
n=R(),m=R();
for(int i=;i<;i++)
tree[].son[i]=;
tree[tot=].clear();
for(int i=;i<=n;i++)
{
scanf("%s",s);
build();
}
buildfail();
scanf("%s",s);
int len=strlen(s),a;
int now=,ans=;
for(int i=;i<len;i++)
{
now=tree[now].son[s[i]-'a'];
ans+=tree[now].cnt;
}
W(ans),putchar('\n');
while(m--)
{
a=R();scanf("%s",t);
int now=,ans1=,ans2=;
for(int i=max(,a-maxx);i<=min(a+maxx-,len-);i++)
{
now=tree[now].son[s[i]-'a'];
ans1+=tree[now].cnt;
}
ans-=ans1;
s[a-]=t[];now=;
for(int i=max(,a-maxx);i<=min(a+maxx-,len-);i++)
{
now=tree[now].son[s[i]-'a'];
ans2+=tree[now].cnt;
}
ans+=ans2;
W(ans),putchar('\n');
}
return ;
}
刷题总结——字符串(ssoj)的更多相关文章
- LeetCode刷题总结-字符串篇
本文梳理对LeetCode上有关字符串习题的知识点,并给出对应的刷题建议.本文建议刷题的总数为32题.具体知识点如下图: 1.回文问题 题号:5. 最长回文子串,难度中等 题号:214. 最短回文串, ...
- leetcode刷题记录——字符串
242.有效地字母异位词 由于本题的字符串只包含 26 个小写字符,因此可以使用长度为 26 的整型数组对字符串出现的字符进行统计,并对比字母出现的次数是否一致.不再使用 HashMap. toCha ...
- leetcode刷题-43字符串相乘
题目 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 思路 字符串转数字:从字符串第一位开始取,每次取出的值转换为数字 ...
- LeetCode随缘刷题之字符串转换整数
package leetcode.day_01_29; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * 请你 ...
- leetCode刷题(将字符串转成W形状的字符串再以Z形字符串输出)
The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like ...
- 刷题总结——date(ssoj)
题目: 题目背景 SOURCE:NOIP2015-SHY-9 题目描述 小Y和小Z好不容易有机会相见啦,可是邪恶的小H却不想让他们相见.现在有一些城市,城市之间有双向路径相连,有路径相连的城市之间可以 ...
- LeetCode刷题指南(字符串)
作者:CYC2018 文章链接:https://github.com/CyC2018/CS-Notes/blob/master/docs/notes/Leetcode+%E9%A2%98%E8%A7% ...
- leecode刷题(16)-- 字符串转换整数
leecode刷题(16)-- 字符串转换整数 字符串转换整数 描述: 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格 ...
- <LC刷题二>回文字符串判断之leetcode125&234
其他刷题记录见博客首页 1,leecode125 验证回文串 原题: 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写. 说明:本题中,我们将空字符串定义为有效的回文串. ...
随机推荐
- spring5之SAXParseException:cvc-elt.1: 找不到元素 “beans” 的声明
之前SSM项目一直报错,就是找不到错误 气啊 后来在网上找到了答案:燕来spring5之后就不再需要写版本号了
- javaweb基础(24)_jsp一般的标签开发
一.标签技术的API 1.1.标签技术的API类继承关系 二.标签API简单介绍 2.1.JspTag接口 JspTag接口是所有自定义标签的父接口,它是JSP2.0中新定义的一个标记接口,没有任何属 ...
- Python——基本运算符
计算机不止可以进行加减乘除,还可以进行多种运算,比如算数运算,逻辑运算,赋值运算等 算数运算 以下假设变量:a=10,b=20 比较运算 以下假设变量:a=10,b=20 赋值运算 以下假设变量:a= ...
- iOS调用WebService接口
首先有几点说在前面 一般,在请求URL的后面带有WSDL字样的需要调用WebService URL样式例子:http://ip:port/navigable/webservice/loginSeric ...
- on() 和 click() 的区别
on() 和 click() 的区别: 二者在绑定静态控件时没有区别,但是如果面对动态产生的控件,只有 on() 能成功的绑定到动态控件中. 以下实例中原先的 HTML 元素点击其身后的 Delete ...
- ANSI C 与 K&R C
C语言由Dennis M.Ritchie在1973年设计和实现.从那以后使用者逐渐增加.到1978年Ritchie和Bell实验室的另一位程序专家Kernighan合写了著名的<TheC Pro ...
- 重温经典之赫夫曼(Huffman)编码
先看看赫夫曼树假设有n个权值{w1,w2,…,wn},构造一个有n个叶子结点的二叉树,每个叶子结点权值为wi,则其中带权路径长度WPL最小的二叉树称作赫夫曼树或最优二叉树. 赫夫曼树的构造,赫夫曼最早 ...
- Visual Studio 2017 UTF-8 无 BOM 一站式解决办法
问题背景:最近捡起C++,使用VS 2017平台.因为以前的编程习惯,喜欢使用UTF-8 无 BOM 的编码格式,好让自己的代码全球通用.但是VS 2017 对这个问题不是很友善.但最终找到了解决办法 ...
- html5音频audio对象处理以及ios微信端自动播放和息屏后唤醒的判断---可供参考(功能都完整实现了,只是细节还没处理的很好)
// html模版中的 此处结合了weui样式整合的微信手机端片段代码(不可直接粘贴复制进行使用)里面含有一些php的写法,可直接略过..###重点参考js代码### <div> < ...
- C# NotifyIcon 托盘控件
右下角以图标形式显示,双击图标显示界面,最小化界面时不显示在任务栏. 第一步:在界面上添加NotifyIcon控件. 第二步:设置notifyIcon1的属性,添加图标,将Visible设为true. ...