[bzoj4943]蚯蚓排队
询问相当于要求长度为k的公共子串个数,很容易联想到hash,由于询问是对全局的,因此对全局开一个hash的桶
对于合并/删除操作,将中间新产生/需要删除的字符串暴力修改即可,单次复杂度最坏为$o(k^{2})$
这样看上去复杂度是$o(nk^{2})$的,但考虑最终的字符串总数$o(nk)$,删除操作最多删掉$o(ck^{2})$,而$\sum 合并复杂度-\sum 删除复杂度=o(nk)$,因此合并复杂度均摊仅为$o(nk)$
但这样的字符串个数挺多的,那么模数就要比较大,而且还不能用map(会TLE),可以再对结果取模然后挂链即可

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 200005
4 #define K 50
5 #define P 4999999
6 #define mod 998244353
7 #define ll unsigned long long
8 struct ji{
9 int nex,tot;
10 ll val;
11 }edge[N*100];
12 int E,n,m,p,x,y,f[K<<2],a[N],pre[N],nex[N],head[P+100];
13 char s[N*50];
14 void add(ll x,int y){
15 int z=x%P;
16 for(int i=head[z];i!=-1;i=edge[i].nex)
17 if (edge[i].val==x){
18 edge[i].tot+=y;
19 return;
20 }
21 edge[E].nex=head[z];
22 edge[E].val=x;
23 edge[E].tot=y;
24 head[z]=E++;
25 }
26 int query(ll x){
27 int y=x%P;
28 for(int i=head[y];i!=-1;i=edge[i].nex)
29 if (edge[i].val==x)return edge[i].tot;
30 return 0;
31 }
32 void update(int x,int y,int p){
33 int l=K,r=K+1;
34 for(int i=x;(i)&&(l);i=pre[i],l--)f[l]=a[i];
35 for(int i=y;(i)&&(r<=K*2);i=nex[i],r++)f[r]=a[i];
36 l++;
37 r--;
38 for(int i=K;i>=l;i--){
39 ll hash=0;
40 for(int j=i;j<=K;j++)hash=hash*11+f[j];
41 for(int j=K+1;j<=min(r,i+K-1);j++){
42 hash=hash*11+f[j];
43 add(hash,p);
44 }
45 }
46 if (p<0)nex[x]=pre[y]=0;
47 else{
48 nex[x]=y;
49 pre[y]=x;
50 }
51 }
52 int main(){
53 scanf("%d%d",&n,&m);
54 memset(head,-1,sizeof(head));
55 for(int i=1;i<=n;i++){
56 scanf("%d",&a[i]);
57 add(a[i],1);
58 }
59 for(int i=1;i<=m;i++){
60 scanf("%d",&p);
61 if (p==1){
62 scanf("%d%d",&x,&y);
63 update(x,y,1);
64 }
65 if (p==2){
66 scanf("%d",&x);
67 y=nex[x];
68 update(x,y,-1);
69 }
70 if (p==3){
71 scanf("%s%d",s,&x);
72 y=strlen(s);
73 ll mi=1,hash=0;
74 for(int j=0;j<x;j++){
75 mi=mi*11;
76 hash=hash*11+s[j]-'0';
77 }
78 int ans=query(hash);
79 for(int j=x;j<y;j++){
80 hash=hash*11+s[j]-'0'-(s[j-x]-'0')*mi;
81 ans=1LL*ans*query(hash)%mod;
82 }
83 printf("%d\n",ans);
84 }
85 }
86 }
[bzoj4943]蚯蚓排队的更多相关文章
- 【BZOJ4943】【NOI2017】蚯蚓排队(哈希)
[BZOJ4943][NOI2017]蚯蚓排队(哈希) 题面 BZOJ 洛谷 UOJ 题解 记得去年看网络同步赛的时候是一脸懵逼的. 昨天看到\(zsy\)做了,今天就看了看.. 这不是\(Hash\ ...
- 【NOI】2017 蚯蚓排队(BZOJ 4943,LOJ 2303) 模拟+hash
[题目]#2303. 「NOI2017」蚯蚓排队 [题意]给定n条长度不超过6的蚯蚓,初始各自在一个队伍.m次操作:1.将i号蚯蚓和j号蚯蚓的队伍合并(保证i为队尾,j为队首).2.将i号蚯蚓和它后面 ...
- LOJ2303 「NOI2017」蚯蚓排队
「NOI2017」蚯蚓排队 题目描述 蚯蚓幼儿园有$n$只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从$1$到$n$的连续正整数编号.每只蚯蚓的长度可以用一个正整数表示 ...
- 「NOI2017」蚯蚓排队 解题报告
「NOI2017」蚯蚓排队 这题真的草 你考虑\(k\)这么小,每次合并两个串,增加的有用串的数量是\(O(k^2)\)的,暴力加入这些串,求一下这些串的Hash值,塞到Hash表里面去 这里采用类似 ...
- BZOJ4943 NOI2017蚯蚓排队(哈希+链表)
能看懂题就能想到正解.维护所有长度不超过k的数字串的哈希值即可,用链表维护一下蚯蚓间连接情况.由于这样的数字串至多只有nk个,计算哈希值的总复杂度为O(nk),而分裂的复杂度为O(ck^2),询问复杂 ...
- BZOJ4943 & 洛谷3823 & UOJ315:[NOI2017]蚯蚓排队——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4943 http://uoj.ac/problem/315 https://www.luogu.or ...
- 【uoj#315/bzoj4943】[NOI2017]蚯蚓排队 Hash
题目描述 给出 $n$ 个字符,初始每个字符单独成字符串.支持 $m$ 次操作,每次为一下三种之一: $1\ i\ j$ :将以 $i$ 结尾的串和以 $j$ 开头的串连到一起. $2\ i$ :将 ...
- bzoj4943 [Noi2017]蚯蚓排队
题面:http://www.lydsy.com/JudgeOnline/upload/Noi2017D1.pdf 正解:字符串$hash$. 我在考场上写了个$map$的$hash$被卡成$40$分, ...
- [NOI 2017]蚯蚓排队
Description 题库链接 蚯蚓幼儿园有 \(n\) 只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从 \(1\) 到 \(n\) 的连续正整数编号.每只蚯蚓的长度 ...
随机推荐
- enum 试图表达64位数
enum AttributeType: unsigned long long{ aa = 1, bb = 2, cc = 0x842AC1040000}; int main() { DWORD64 b ...
- SpringMVC 数据响应
页面跳转 返回字符串形式 直接返回字符串:此种方式会将返回的字符串与视图解析器的前后缀拼接后跳转. @RequestMapping("/quick") public String ...
- PAT (Basic Level) Practice (中文)1025 反转链表 (25分)
1025 反转链表 (25分) 给定一个常数 K 以及一个单链表 L,请编写程序将 L 中每 K 个结点反转.例如:给定 L 为 1→2→3→4→5→6,K 为 3,则输出应该为 3→2→1→6→5→ ...
- Coursera Deep Learning笔记 改善深层神经网络:优化算法
笔记:Andrew Ng's Deeping Learning视频 摘抄:https://xienaoban.github.io/posts/58457.html 本章介绍了优化算法,让神经网络运行的 ...
- pagelayout在py中的引用不支持size_hint和pos_hint
from kivy.uix.pagelayout import PageLayout from kivy.uix.button import Button from kivy.app import A ...
- 软件案例分析——VS和VS Code
软件案例分析--VS和VS Code 项目 内容 这个作业属于哪个课程/ 2020年春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里? 软件案例分析 我在这个课程的目标是? 提高代码水平,熟 ...
- [暴力题解&&考试反思] 双十一欢乐赛(联赛膜你测试32)
前言: 今天考试很迷糊.从7点考到11点半,我大概从7点睡到9点.隐隐约约看到旁边的狗哥敲了好几个题,我才开始写代码.然后因为还是很困,而且T1迷迷糊糊调了好长时间,T3T4的暴力就懒的写了... 估 ...
- CodeForces-1076E Vasya and a Tree
CodeForces - 1076E Problem Description: Vasya has a tree consisting of n vertices with root in verte ...
- [源码解析] PyTorch 如何实现后向传播 (4)---- 具体算法
[源码解析] PyTorch 如何实现后向传播 (4)---- 具体算法 目录 [源码解析] PyTorch 如何实现后向传播 (4)---- 具体算法 0x00 摘要 0x01 工作线程主体 1.1 ...
- cm3 逆向分析
目录 cm3 逆向分析 前言 逆向分析 cm3 逆向分析 前言 这道题没加壳,也没加密算法,主要看代码逻辑. 逆向分析 代码很短,一共这么几句. 看提示知道只让我们输入w.s.a.d这几个字符,并且用 ...