洛咕 P2336 [SCOI2012]喵星球上的点名


先求出SA和height,一个点名串对应的就是一段区间,还有很多个点,就转化成了

有很多个区间,很多个点集,对每个区间计算和多少个点集有交,对每个点集计算和多少个区间有交。

第一个,HH的项链的树状数组做法

第二个,因为是点集所以要去重,假设点集有\(a_1,a_2,\cdots,a_k\),可以对每个区间只再覆盖的第一个点做记录

就是记录\(\sum_{i=1}^k\sum_{\texttt{interval }[l,r]}\left[l\in[a_{i-1}+1,a_i],r\geq a_i\right]\)

#include<bits/stdc++.h>
#define il inline
#define vd void
typedef long long ll;
il int gi(){
int x=0,f=1;
char ch=getchar();
while(!isdigit(ch)){
if(ch=='-')f=-1;
ch=getchar();
}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
std::vector<int>A[100010],B[100010],C[100010],S,P;
int len,x[400010],y[400010],t[400010],SA[400010],rk[400010];
int ht[400010];
il bool cmp(int a,int b,int k){return y[a]==y[b]&&y[a+k]==y[b+k];}
int ans1[100010],ans2[100010];
int lg[400010],st[19][400010];
il int query(int l,int r){
int g=lg[r-l+1];
return std::min(st[g][l],st[g][r-(1<<g)+1]);
}
std::vector<int>ins[400010],del[400010],p_del[400010];
int Tree[400010],Tree2[400010],lst[400010],LL[400010],RR[400010];
il vd update(int*t,int p,int x){while(p<=len)t[p]+=x,p+=p&-p;}
il int query(int*t,int r){int ret=0;while(r)ret+=t[r],r-=r&-r;return ret;}
int main(){
int n=gi(),m=gi();
for(int i=1;i<=n;++i){
len=gi();
while(len--)A[i].push_back(gi()+200000);
len=gi();
while(len--)B[i].push_back(gi()+200000);
}
for(int i=1;i<=m;++i){
len=gi();
while(len--)C[i].push_back(gi()+200000);
}
S.push_back(233333);
P.push_back(0);
int sep=0;
for(int i=1;i<=n;++i){
S.insert(S.end(),A[i].begin(),A[i].end());
S.push_back(++sep);
for(int j=0;j<A[i].size();++j)P.push_back(i);
P.push_back(0);
}
for(int i=1;i<=n;++i){
S.insert(S.end(),B[i].begin(),B[i].end());
S.push_back(++sep);
for(int j=0;j<B[i].size();++j)P.push_back(i);
P.push_back(0);
}
for(int i=1;i<=m;++i){
S.insert(S.end(),C[i].begin(),C[i].end());
S.push_back(++sep);
P.push_back(-i);
for(int j=0;j<C[i].size();++j)P.push_back(0);
}
len=S.size()-1;
int tot=400000;
for(int i=1;i<=len;++i)++t[x[i]=S[i]];
for(int i=1;i<=tot;++i)t[i]+=t[i-1];
for(int i=len;i;--i)SA[t[x[i]]--]=i;
for(int k=1;k<=len;k<<=1){
int p=0;
for(int i=0;i<=tot;++i)y[i]=0;
for(int i=len-k+1;i<=len;++i)y[++p]=i;
for(int i=1;i<=len;++i)if(SA[i]>k)y[++p]=SA[i]-k;
for(int i=0;i<=tot;++i)t[i]=0;
for(int i=1;i<=len;++i)++t[x[y[i]]];
for(int i=1;i<=tot;++i)t[i]+=t[i-1];
for(int i=len;i;--i)SA[t[x[y[i]]]--]=y[i];
std::swap(x,y),x[SA[1]]=p=1;
for(int i=2;i<=len;++i)x[SA[i]]=cmp(SA[i],SA[i-1],k)?p:++p;
if(p>=len)break;tot=p;
}
for(int i=1;i<=len;++i)rk[SA[i]]=i;
int k=0;
for(int i=1;i<=len;++i){
if(rk[i]==len)continue;
if(k)--k;
int j=SA[rk[i]+1];
while(S[i+k]==S[j+k])++k;
ht[rk[i]]=k;
}
for(int i=2;i<=len;++i)lg[i]=lg[i>>1]+1;
for(int i=1;i<len;++i)st[0][i]=ht[i];
for(int i=1;i<=lg[len];++i)
for(int j=1;j+(1<<i)-1<len;++j)
st[i][j]=std::min(st[i-1][j],st[i-1][j+(1<<i-1)]);
for(int i=1;i<=len;++i)
if(P[SA[i]]<0){
int l=1,r=i,mid,sz=C[-P[SA[i]]].size();
while(l<r){
mid=(l+r)>>1;
if(query(mid,i-1)<sz)l=mid+1;
else r=mid;
}
int L=l;
ins[l].push_back(L);
LL[-P[SA[i]]]=l;
l=i,r=len;
while(l<r){
mid=(l+r)>>1;
if(query(i,mid)>=sz)l=mid+1;
else r=mid;
}
del[l+1].push_back(L);
p_del[l+1].push_back(-P[SA[i]]);
RR[-P[SA[i]]]=l;
}
for(int i=1;i<=len;++i){
if(P[SA[i]]>0){
update(Tree2,i,1);
if(lst[P[SA[i]]])update(Tree2,lst[P[SA[i]]],-1);
}
for(int j=0;j<ins[i].size();++j)update(Tree,ins[i][j],1);
for(int j=0;j<del[i].size();++j)update(Tree,del[i][j],-1);
if(P[SA[i]]>0){
ans1[P[SA[i]]]+=query(Tree,i)-query(Tree,lst[P[SA[i]]]);
lst[P[SA[i]]]=i;
}
for(int j=0;j<del[i+1].size();++j)ans2[p_del[i+1][j]]=query(Tree2,RR[p_del[i+1][j]])-query(Tree2,LL[p_del[i+1][j]]-1);
}
for(int i=1;i<=m;++i)printf("%d\n",ans2[i]);
for(int i=1;i<=n;++i)printf("%d ",ans1[i]);
puts("");
return 0;
}

洛咕 P2336 [SCOI2012]喵星球上的点名的更多相关文章

  1. 洛谷 P2336 [SCOI2012]喵星球上的点名 解题报告

    P2336 [SCOI2012]喵星球上的点名 题目描述 a180285 幸运地被选做了地球到喵星球的留学生.他发现喵星人在上课前的点名现象非常有趣. 假设课堂上有 \(N\) 个喵星人,每个喵星人的 ...

  2. 洛谷P2336 [SCOI2012]喵星球上的点名(后缀数组+莫队)

    我学AC自动机的时候就看到了这题,想用AC自动机结果被学长码风劝退-- 学后缀数组时又看到了这题--那就写写后缀数组做法吧 结果码风貌似比当年劝退我的学长还毒瘤啊 对所有的模式串+询问串,不同串之间用 ...

  3. P2336 [SCOI2012]喵星球上的点名(后缀自动机+莫队+dfs序)

    P2336 [SCOI2012]喵星球上的点名 名字怎么存?显然是后缀自动机辣 询问点到多少个喵喵喵其实就是 查询后缀自动机上parent树的一个子树 于是我们考虑莫队 怎么树上莫队呢 我们用dfs序 ...

  4. Luogu P2336 [SCOI2012]喵星球上的点名

    题目链接 \(Click Here\)_ \(200\)行纯干货的代码,一发\(WA\)掉真的是让人窒息,幸好最后找到了锅在哪.(差点就要弃掉了\(QAQ\)) [调出来的时候真的是要高兴到哭出来了\ ...

  5. P2336 [SCOI2012]喵星球上的点名(SA+莫队)

    题面传送门 一道还算有点含金量的 SA 罢-- 首先按照套路我们把读入的所有字符串都粘在一起,中间用分隔符隔开并建出后缀数组出来. 我们考虑对于一个固定的字符串 \(s\),什么样的字符串 \(t\) ...

  6. BZOJ 2754: [SCOI2012]喵星球上的点名 [后缀数组+暴力]

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1906  Solved: 839[Submit][St ...

  7. 【BZOJ2754】[SCOI2012]喵星球上的点名

    [BZOJ2754][SCOI2012]喵星球上的点名 题面 bzoj 洛谷 题解 这题有各种神仙做法啊,什么暴力\(AC\)自动机.\(SAM\)等等五花八门 我这个蒟蒻在这里提供一种复杂度正确且常 ...

  8. BZOJ 2754: [SCOI2012]喵星球上的点名

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 649  Solved: 305[Submit][Sta ...

  9. BZOJ2754: [SCOI2012]喵星球上的点名

    2754: [SCOI2012]喵星球上的点名 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 680  Solved: 314[Submit][Sta ...

随机推荐

  1. Python 数据分析基础小结

    一.数据读取 1.读写数据库数据 读取函数: pandas.read_sql_table(table_name, con, schema=None, index_col=None, coerce_fl ...

  2. 理解 Azure 平台中虚拟机的计算能力

    虚拟化平台至今已经发展了十多年的时间.其中 Hyper-V 技术现在也已经是第三代版本.用户对于虚拟化计算也越来越接受,这也有了公有云发展的基础.然而在很多时候,用户在使用基于 Hyper-V 的 A ...

  3. cut切割,简单的取列

    cut 切割,简单的取列命令. -d 指定分隔符 -f 数字 取第几列 -c n-m 取n列到m列字符. //提取字符,不常用 例如:已知bqh.txt文件里的内容为“I am bqh myqq is ...

  4. 【转】Linxu学习---top实践

    [原文]https://www.toutiao.com/i6591053058258502147/ 在实际开发中,有时候会收到一些服务的监控报警,比如CPU飙高,内存飙高等,这个时候,我们会登录到服务 ...

  5. 笔记本键盘开关方法 仅限window系统

    按win键,搜索CMD(命令提示符).右键-以管理员身份运行.关闭笔记本键盘输入:sc config i8042prt start= disabled回车-重启电脑即可.需要重新启用键盘的话,输入:s ...

  6. 【8】python文件的读写方法

    (1).读文件的步骤: (1)打开文件 open(path,flag,encoding,[errors]) path:打开路径 flag:打开方式 r(只读) rb(二进制格式) r+(可以读写) w ...

  7. Case Study: 技术和商业的结合点在哪里?

    如果要制作过去两三年里最火爆的企业级产品创业公司名单,里面一定少不了一家叫做Docker的公司.先别管Docker是做什么的,只要记住这是这几年企业级IT产品里最重要的热点技术,有一半的大型企业已经在 ...

  8. centos7装机教程

    U盘启动电脑进入安装界面 正常情况下你应该会看到下面的这个界面: 选择第一项,然后按TAB键,然后会看到下面这个: 3.修改第二步中按TAB键出来的命令 将命令修改为:>vmlinuz init ...

  9. Use MusicBrainz in iOS(三)查询专辑的完整信息

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u010962810/article/details/24066737 本文讨论下通过专辑名获取专辑的 ...

  10. android 实现mqtt消息推送,以及不停断线重连的问题解决

    前段时间项目用到mqtt的消息推送,整理一下代码,代码的原型是网上找的,具体哪个地址已经忘记了. 代码的实现是新建了一个MyMqttService,全部功能都在里面实现,包括连服务器,断线重连,订阅消 ...