bzoj4943 [Noi2017]蚯蚓排队
2024-10-21 19:45:33
题面:http://www.lydsy.com/JudgeOnline/upload/Noi2017D1.pdf
正解:字符串$hash$。
我在考场上写了个$map$的$hash$被卡成$40$分,然后改成挂链版本的就$AC$了。。$mdzz$,以后$hash$再也不写$map$了。。
我们考虑使用链表来表示字符间的关系,合并和分裂都用链表来表示,这样我们可以快速找到两个字符的前$k$个和后$k$个字符。
注意到每次只会增加或减少$k^{2}$个字符串,那么我们直接把这些字符串$hash$起来即可,查询统计也很简单。
这道题好像是被骂得最惨的一道题??有人说出题人想告诉我们$SAM$,后缀数组这些高级字符串数据结构都没用。。
//It is made by wfj_2048~
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#define rhl (998244353)
#define wyh (19260817)
#define M (10000010)
#define N (300010)
#define il inline
#define RG register
#define ll long long
#define ull unsigned long long using namespace std; struct edge{ int nt,sum; ull v; }g[]; int head[wyh+],a[N],lst[N],nxt[N],st1[],st2[],tong[],n,m,num,fg,top1,top2;
ull hsh[M],bin[M],base=;
char s[M];
ll ans; il int gi(){
RG int x=,q=; RG char ch=getchar();
while ((ch<'' || ch>'') && ch!='-') ch=getchar();
if (ch=='-') q=-,ch=getchar();
while (ch>='' && ch<='') x=x*+ch-,ch=getchar();
return q*x;
} il void insert(RG int from,RG ull to){
g[++num]=(edge){head[from],,to},head[from]=num; return;
} il void add(RG ull Hash){
RG int ymd=Hash%wyh;
for (RG int i=head[ymd];i;i=g[i].nt)
if (g[i].v==Hash){ ++g[i].sum; return; }
return insert(ymd,Hash);
} il void del(RG ull Hash){
RG int ymd=Hash%wyh;
for (RG int i=head[ymd];i;i=g[i].nt)
if (g[i].v==Hash){ --g[i].sum; return; }
return;
} il ll calc(RG ull Hash){
RG int ymd=Hash%wyh;
for (RG int i=head[ymd];i;i=g[i].nt)
if (g[i].v==Hash) return g[i].sum;
return ;
} int main(){
#ifndef ONLINE_JUDGE
freopen("queue.in","r",stdin);
freopen("queue.out","w",stdout);
#endif
n=gi(),m=gi(),fg=,bin[]=;
for (RG int i=;i<=;++i) bin[i]=bin[i-]*base;
for (RG int i=;i<=n;++i){ a[i]=gi(),++tong[a[i]]; if (a[i]!=) fg=; }
for (RG int i=;i<=n;++i) lst[i]=nxt[i]=i;
for (RG int p=,op,x,y,k,len;p<=m;++p){
op=gi();
if (op==){
x=gi(),y=gi(),top1=top2=,st1[++top1]=x,st2[++top2]=y;
for (RG int i=x;top1< && lst[i]!=i;i=lst[i]) st1[++top1]=lst[i];
for (RG int i=y;top2< && nxt[i]!=i;i=nxt[i]) st2[++top2]=nxt[i];
RG ull Hsh=; for (RG int i=top1;i;--i) Hsh=Hsh*base+a[st1[i]]; st1[top1+]=;
for (RG int i=top1;i;--i){
RG ull Hash=Hsh-a[st1[i+]]*bin[i]; Hsh=Hash,len=i;
for (RG int j=;j<=top2;++j){
++len; if (len>) break;
Hash=Hash*base+a[st2[j]],add(Hash);
}
}
nxt[x]=y,lst[y]=x;
}
if (op==){
x=gi(),y=nxt[x],top1=top2=,st1[++top1]=x,st2[++top2]=y;
for (RG int i=x;top1< && lst[i]!=i;i=lst[i]) st1[++top1]=lst[i];
for (RG int i=y;top2< && nxt[i]!=i;i=nxt[i]) st2[++top2]=nxt[i];
RG ull Hsh=; for (RG int i=top1;i;--i) Hsh=Hsh*base+a[st1[i]]; st1[top1+]=;
for (RG int i=top1;i;--i){
RG ull Hash=Hsh-a[st1[i+]]*bin[i]; Hsh=Hash,len=i;
for (RG int j=;j<=top2;++j){
++len; if (len>) break;
Hash=Hash*base+a[st2[j]],del(Hash);
}
}
nxt[x]=x,lst[y]=y;
}
if (op==){
scanf("%s",s+),k=gi(),len=strlen(s+),ans=; RG ull Hash;
if (k==){
for (RG int i=;i<=len;++i) ans=ans*(ll)tong[s[i]-]%rhl;
printf("%lld\n",ans); continue;
}
for (RG int i=;i<=len;++i) hsh[i]=hsh[i-]*base+s[i]-;
for (RG int i=;i+k-<=len;++i){
Hash=hsh[i+k-]-hsh[i-]*bin[k];
ans=ans*calc(Hash)%rhl;
}
printf("%lld\n",ans);
}
}
return ;
}
最新文章
- 制做RPM包
- 【Fate/kaleid liner 魔法少女☆伊莉雅】系列中实践的、新世代的动画摄影工作流
- [leetcode]_Longest Substring Without Repeating Characters
- SpringMVC 中的Interceptor 拦截器
- hdu 1175(广搜)
- Core Data (2)-备用
- while和for可以相互转换例子
- AutoCAD 2014简体中文版官方正式版x86 x64下载,带注册机,永久免费使用
- jarsigner
- MOSFET与MOSFET驱动电路原理及应用(转)
- 两个同级div等高布局
- Spring学习(8)--- @Autowired注解(一)
- python笔记四(dict/set/不可变对象)
- 在Linux上要安装SSH协议
- 使用ajax分页查询
- 线程同步的实现方式(volatile、synchronized、CountDownLatch)
- select实现高并发服务器
- JS基础(一)dom小实例
- 带你玩转Visual Studio——带你了解VC++各种类型的工程
- ORA-12519 ORA-12516
热门文章
- MySQL SQL_MODE详解
- Windows安装redis数据库以及集群部署
- centos7-根据端口号查看所属应用
- SQL SERVER – Configuration Manager – Cannot Connect to WMI Provider. You Do Not Have Permission or The Server is Unreachable
- 使用Ext 创建树
- 【3dsMax安装失败,如何卸载、安装3dMax 2017?】
- WSGI学习系列多种方式创建WebServer
- (转)总结Linux的chattr与lsattr命令详解
- kindEditor完整认识 PHP上调用并上传图片说明
- php和c++socket通讯(基于字节流,二进制)