这题看题面感觉挺玄学的,但其实会挂链式hash就能暴力切了,就是纸老虎,考察选手的语文水平。不过三年没写挂链hash也应该写一下了……

首先模数设成自然溢出ull,然后挂链时的模数取2^24。然后就可以直接hash了。对于3操作直接O(Σ|S|)询问即可,对于1、2操作,直接暴力加、减长度不超过50的字符,毕竟k<=50,这是个关键性条件。所以暴力能切了。

下面分析时间复杂度:先假设没有2操作,因为每一个位置只有长度不超过50的,每次加的数量也是不超过50的,这样总复杂度是均摊O(nk)的;再考虑2操作,因为2操作数量很少,而且每次只会至多影响O(k2)个数,因此考虑2操作后,复杂度是O(ck2)的,于是总复杂度是O(nk+ck2+Σ|S|)。注意hash不能用map,要挂链,因为map自带大常数和log,为什么不能unordered_map呢?因为这是NOI,不能用c++11。

#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ull;
const int N=5e5+,p=,mod=,gloid=(<<)-;
int n,m,q,a[N],pre[N],nxt[N],cnt[N],f[];
ull h[],pw[];
char s[];
struct Hash{
struct edge{ull x;int v,nxt;}e[];
int hd[gloid+],ecnt;
void add(ull x,int d)
{
int u=x&gloid;
for(int i=hd[u];i;i=e[i].nxt)if(e[i].x==x){e[i].v+=d;return;}
e[++ecnt]=(edge){x,d,hd[u]},hd[u]=ecnt;
}
int query(ull x)
{
int u=x&gloid;
for(int i=hd[u];i;i=e[i].nxt)if(e[i].x==x)return e[i].v;
return ;
}
}mp;
void merge()
{
int x,y,L=,R=;scanf("%d%d",&x,&y);
memset(f,,sizeof f);
for(int i=x;i&&L>;i=pre[i])f[--L]=a[i];
for(int i=y;i&&R<;i=nxt[i])f[++R]=a[i];
for(int i=;i<=R;i++)h[i]=h[i-]*p+f[i];
for(int i=L;i<=;i++)
for(int j=;j<=min(R,i+);j++)
mp.add(h[j]-h[i-]*pw[j-i+],);
nxt[x]=y,pre[y]=x;
}
void split()
{
int x,y,L=,R=;scanf("%d",&x),y=nxt[x];
memset(f,,sizeof f);
for(int i=x;i&&L>;i=pre[i])f[--L]=a[i];
for(int i=y;i&&R<;i=nxt[i])f[++R]=a[i];
for(int i=;i<=R;i++)h[i]=h[i-]*p+f[i];
for(int i=L;i<=;i++)
for(int j=;j<=min(R,i+);j++)
mp.add(h[j]-h[i-]*pw[j-i+],-);
nxt[x]=pre[y]=;
}
int query()
{
scanf("%s",s+);
int len=strlen(s+),ret=,k;
scanf("%d",&k);
ull val=;
if(k==)
{
for(int i=;i<=len;i++)ret=1ll*ret*cnt[s[i]]%mod;
return ret;
}
for(int i=;i<=len;i++)
{
val=val*p+s[i];
if(i>k)val-=pw[k]*s[i-k];
if(i>=k)ret=1ll*ret*mp.query(val)%mod;
}
return ret;
}
int main()
{
scanf("%d%d",&n,&q);
pw[]=;for(int i=;i<=;i++)pw[i]=pw[i-]*p;
for(int i=;i<=n;i++)scanf("%d",&a[i]),a[i]+='',cnt[a[i]]++;
while(q--)
{
int op;scanf("%d",&op);
if(op==)merge();
else if(op==)split();
else printf("%d\n",query());
}
}

[NOI2017]蚯蚓排队(链表+hash)的更多相关文章

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

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

  2. BZOJ4943 NOI2017蚯蚓排队(哈希+链表)

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

  3. [NOI2017]蚯蚓排队 hash

    题面:洛谷 题解: 我们暴力维护当前所有队伍内的所有子串(长度k = 1 ~ 50)的出现次数. 把每个子串都用一个hash值来表示,每次改变队伍形态都用双向链表维护,并暴力更新出现次数. 现在考虑复 ...

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

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

  5. LOJ 2303 「NOI2017」蚯蚓排队——链表+哈希表

    题目:https://loj.ac/problem/2303 想到合并的时候可以只考虑接口附近的50个,但不太会分析复杂度,而且没有清楚地想到用哈希值对应个数. 看了题解才会…… 一直想用 splay ...

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

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

  7. bzoj4943 [Noi2017]蚯蚓排队

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

  8. [NOI2017]蚯蚓排队

    嘟嘟嘟 现在看来这道题还不是特别难. 别一看到字符串就想SAM 看到\(k\)很小,所以我们可以搞一个单次修改复杂度跟\(k\)有关的算法. 能想到,每一次断开或链接,最多只会影响\(k ^ 2\)个 ...

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

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

随机推荐

  1. UVA - 1572 Self-Assembly(图论模型+拓扑排序)

    题意:判断利用给出的正方形是否能拼接出无限延伸的结构. 分析:正方形上的字母看做点,正方形看做有向边. 例如: 若上下两个正方形能拼接,需要B+~C+是个有向边. 对输入的处理是:把A+,A-分别映射 ...

  2. cf 785#

    23333再次水惨了..(心酸啊) A题呵呵呵呵呵 #include<cstdio> #include<iostream> using namespace std; int m ...

  3. 联系我们地图坐标展示js

    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=6d88 ...

  4. 快速搭建单机版Spring Cloud EurekaServer

    原文链接:http://www.yiidian.com/springcloud/build-eureka-single.html 本文介绍搭建单机版的Eureka Server服务 1 创建项目,导入 ...

  5. c++ 字符串转数字或数字转字符串

    在C++中字符串转换为数字,或数字转换为字符串,用到如下函数: _itoa atoi.atof.itoa.itow _itoa_s 1.整形转换为字符串: wchar_t * _itot(int _V ...

  6. 【pwnable.kr】passcode

    pwnable从入门到放弃,第六题. ssh passcode@pwnable.kr -p2222 (pw:guest) 完全是‘&’的锅. #include <stdio.h> ...

  7. 大数据高可用集群环境安装与配置(05)——安装zookeeper集群

    1. 下载安装包 登录官网下载安装包 https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/ 2. 执行命令下载并安装 cd /usr/local ...

  8. bzoj 4247挂饰

    背包????不会... #include<bits/stdc++.h> #define INF 0x7fffffff #define LL long long #define N 1000 ...

  9. bzoj 4195程序自动分析

    先离散一下,然后并查集就好了. (一开始作大死,没全离散,WA一片) #include<bits/stdc++.h> #define INF 0x7fffffff #define LL l ...

  10. DevOps元数据管理

    元数据是自动化运维的基础,对元数据的管理和查询贯穿整个运维的生命周期.我们从一个元数据的使用场景开始: 双十一抢购火热进行中,某电商后端实例的日志中出现了502错误码,运维平台监测到该异常并发送告警给 ...