能看懂题就能想到正解。维护所有长度不超过k的数字串的哈希值即可,用链表维护一下蚯蚓间连接情况。由于这样的数字串至多只有nk个,计算哈希值的总复杂度为O(nk),而分裂的复杂度为O(ck^2),询问复杂度为O(Σ|s|)。于是总复杂度为O(nk+ck^2+Σ|s|)。

  手写哈希注意插入元素时考虑清楚,如果没有哈希冲突不需要更新哈希使用的链表,所以特判一下。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
int x=;char c=getchar();
while (c<''||c>'') c=getchar();
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x;
}
#define N 200010
#define S 10000010
#define K 50
#define P 19260817
#define MOD 998244353
#define G 7
#define ul unsigned long long
int n,m,POW[K+][];
struct data{int x,pre,nxt;
}a[N];
int ch[S];
int map[P+],cnt[P+],nxt[P+];
ul value[P+],POWv[K+][];
void ins(int x,ul v)
{
if (!map[x]) map[x]=,value[x]=v,cnt[x]=;
else
{
int t;
while (map[x]&&value[x]!=v) t=x,x=nxt[x];
if (map[x]) cnt[x]++;
else map[x]=,value[x]=v,cnt[x]=,nxt[t]=x;
}
}
void del(int x,ul v)
{
while (value[x]!=v) x=nxt[x];
cnt[x]--;
}
int query(int x,ul v)
{
while (map[x]&&value[x]!=v) x=nxt[x];
return cnt[x];
}
int main()
{
n=read(),m=read();
for (int i=;i<P-;i++) nxt[i]=i+;nxt[P-]=;
for (int j=;j<=;j++)
{
POW[][j]=j;for (int i=;i<=K;i++) POW[i][j]=POW[i-][j]*G%P;
POWv[][j]=j;for (int i=;i<=K;i++) POWv[i][j]=POWv[i-][j]*G;
}
for (int i=;i<=n;i++) a[i].x=read(),ins(a[i].x,a[i].x);
while (m--)
{
int op=read();
switch(op)
{
case :
{
int x=read(),y=read();
a[x].nxt=y,a[y].pre=x;
for (int l=,h=x;h&&l<K;h=a[h].pre,l++)
{
int hash=;ul hashv=;
for (int i=,t=h;i<=l;t=a[t].nxt,i++)
hash=(hash*G+a[t].x)%P,hashv=hashv*G+a[t].x;
for (int i=l+,t=y;t&&i<=K;t=a[t].nxt,i++)
{
hash=(hash*G+a[t].x)%P,hashv=hashv*G+a[t].x;
ins(hash,hashv);
}
}
break;
}
case :
{
int x=read(),y=a[x].nxt;
for (int l=,h=x;h&&l<K;h=a[h].pre,l++)
{
int hash=;ul hashv=;
for (int i=,t=h;i<=l;t=a[t].nxt,i++)
hash=(hash*G+a[t].x)%P,hashv=hashv*G+a[t].x;
for (int i=l+,t=y;t&&i<=K;t=a[t].nxt,i++)
{
hash=(hash*G+a[t].x)%P,hashv=hashv*G+a[t].x;
del(hash,hashv);
}
}
a[x].nxt=;a[y].pre=;
break;
}
case :
{
char c=getchar();int l=;
while (c<''||c>'') c=getchar();
while (c>=''&&c<='') ch[++l]=c^,c=getchar();
int k=read();
int hash=;ul hashv=;
for (int i=;i<k;i++)
hash=(hash*G+ch[i])%P,hashv=hashv*G+ch[i];
int ans=;
for (int i=k;i<=l;i++)
{
hash=(hash*G+ch[i]-POW[k][ch[i-k]]+P)%P,
hashv=hashv*G+ch[i]-POWv[k][ch[i-k]];
ans=1ll*ans*query(hash,hashv)%MOD;
}
printf("%d\n",ans);
}
}
}
return ;
}

BZOJ4943 NOI2017蚯蚓排队(哈希+链表)的更多相关文章

  1. bzoj4943 [Noi2017]蚯蚓排队

    题面:http://www.lydsy.com/JudgeOnline/upload/Noi2017D1.pdf 正解:字符串$hash$. 我在考场上写了个$map$的$hash$被卡成$40$分, ...

  2. P3823_[NOI2017]蚯蚓排队 哈希+脑子

    之前就写过一遍,今天却写挂了,查了半天发现是数组名写错啦$qwq$ 观察到$K$很小,所以使得我们可以哈希(怎么什么都能哈希$qwq$).我们把长度小于等于$50$的子串扔到哈希表里,并统计出现次数, ...

  3. [Bzoj4943][Noi2017]蚯蚓(hash)

    4943: [Noi2017]蚯蚓 Time Limit: 50 Sec  Memory Limit: 512 MBSubmit: 237  Solved: 110[Submit][Status][D ...

  4. BZOJ4943 & 洛谷3823 & UOJ315:[NOI2017]蚯蚓排队——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4943 http://uoj.ac/problem/315 https://www.luogu.or ...

  5. 洛谷3823 [NOI2017] 蚯蚓排队 【哈希】

    题目分析: 从$\sum|S|$入手.共考虑$\sum|S|$个$f(t)$.所以我们要一个对于每个$f(t)$在$O(1)$求解的算法.不难想到是哈希. 然后考虑分裂和合并操作.一次合并操作要考虑合 ...

  6. 【uoj#315/bzoj4943】[NOI2017]蚯蚓排队 Hash

    题目描述 给出 $n$ 个字符,初始每个字符单独成字符串.支持 $m$ 次操作,每次为一下三种之一: $1\ i\ j$ :将以 $i$ 结尾的串和以 $j$ 开头的串连到一起. $2\ i$ :将 ...

  7. 洛谷P3832 [NOI2017]蚯蚓排队 【链表 + 字符串hash】

    题目链接 洛谷P3832 题解 字符串哈希然后丢到hash表里边查询即可 因为\(k \le 50\),1.2操作就暴力维护一下 经复杂度分析会发现直接这样暴力维护是对的 一开始自然溢出WA了,还以为 ...

  8. [NOI2017]蚯蚓排队(链表+hash)

    这题看题面感觉挺玄学的,但其实会挂链式hash就能暴力切了,就是纸老虎,考察选手的语文水平.不过三年没写挂链hash也应该写一下了…… 首先模数设成自然溢出ull,然后挂链时的模数取2^24.然后就可 ...

  9. BZOJ4943 [NOI2017] 蚯蚓

    题目描述 蚯蚓幼儿园有nn 只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从11 到nn 的连续正整数编号.每只蚯蚓的长度可以用一个正整数表示,根据入园要求,所有蚯蚓的长 ...

随机推荐

  1. <转>安全测试思维导图

    最近有监控到公司的某些系统在某些时间段出现大量的HTTP或者TCP连接,考虑到安全性,老大让我研究研究安全测试... 正好今晚从订阅的码农周刊(开发者头条)看到了一篇安全测试相关的帖子,做个搬运工,分 ...

  2. 包含 PHP和nginx的镜像 supervisord.conf Dockerfile 案例

    参考:https://github.com/romeOz/docker-nginx-php 1.命令: docker run --name app -d -p 8080:80 \ --net pg_n ...

  3. RBAC 基于权限的访问控制 serviceaccount -- clusterRole clusterRoleBinding

    1.Role , RoleBinding 的作用对象都是namespace. 2.通过RoleRef,可以看到,RoleBinding对象通过名字,直接引用前面定义的Role,实现subject(us ...

  4. Android Studio 导入工程

    最简单的方式 等待加载完就好了 第二种方式 在导入别人的android studio项目(假设为项目A)时,会遇到gradle不一致的情况,以下简短介绍解决方法: 1. 打开要导入的项目的目录,删除下 ...

  5. 《Head First 设计模式》[02] 观察者模式

    1.观察者模式 1.1 形象地认识观察者模式 报社的业务是出版报纸 用户像某家报社订阅了报纸,那么一旦报社有新的报纸,就会送到用户处.只要是订户,就一直会收到新报纸: 当用户不再想看报纸时,取消订阅, ...

  6. Luogu4338 ZJOI2018 历史 LCT、贪心

    传送门 题意:在$N$个点的$LCT$中,最开始每条边的虚实不定,给出每一个点的$access$次数,求一种$access$方案使得每条边的虚实变换次数之和最大,需要支持动态增加某个点的$access ...

  7. 记一次网页超时登录的Bug

    前几天,在做全公司的员工测评工作,在一个页面弹出导入页面,并导入所有评价记录,然后关闭掉这个导入页面,最后返回当前页面,返回时刷新当前页面. 在返回的时候,就出现了“页面超时登录”同时返回登录首页的问 ...

  8. C# 实现表单的自动化测试<通过程序控制一个网页>

    学历代表你的过去,能力代表你的现在,学习代表你的将来 十年河东,十年河西,莫欺少年穷 学无止境,精益求精 C# 实现表单的自动化测试,这标题看着就来劲!那么,如何通过C#程序控制一个网页呢? 在此,以 ...

  9. ES6 Promise 异步操作

    最近越来越喜欢与大家进行资源分享了,并且及时的同步到自己的园子内,为什么呢? 一.小插曲(气氛搞起) 在上个月末,由于领导的高度重视(haha,这个高度是有多高呢,185就好了),走进了公司骨干员工的 ...

  10. Scala学习(五)---Scala中的类

    Scala中的类 摘要: 在本篇中,你将会学习如何用Scala实现类.如果你了解Java或C++中的类,你不会觉得这有多难,并且你会很享受Scala更加精简的表示法带来的便利.本篇的要点包括: 1. ...