BZOJ 4516: [Sdoi2016]生成魔咒

时间:2023-02-27 23:58:31

Description

给出一串数字,求每次插入一个数字后本质不同的子串.

Sol

SAM.

在 SAM 上添加节点的时候统计一下 \(val[np]-val[par[np]]\) 就可以了...

用 map 存一下边,复杂度 \(O(nlogn)\)

Code

/**************************************************************
Problem: 4516
User: BeiYu
Language: C++
Result: Accepted
Time:812 ms
Memory:14940 kb
****************************************************************/ #include<cstdio>
#include<cstring>
#include<map>
#include<iostream>
using namespace std; typedef long long LL;
const int N = 200005; int n,cnt,rt,lst;
LL ans;
map<int,int> go[N];
int par[N],val[N]; inline int in(int x=0,char ch=getchar()){ while(ch>'9'||ch<'0') ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();return x; } void Extend(int w=in()){
int p=lst,np=++cnt;
val[np]=val[p]+1;
while(p && go[p][w]==0) go[p][w]=np,p=par[p];
if(!p) par[np]=rt;
else{
int q=go[p][w];
if(val[p]+1 == val[q]) par[np]=q;
else{
int nq=++cnt;
val[nq]=val[p]+1,go[nq]=go[q],par[nq]=par[q];
par[q]=par[np]=nq;
while(p && go[p][w]==q) go[p][w]=nq,p=par[p];
}
}ans+=val[np]-val[par[np]],lst=np;
} int main(){
lst=rt=++cnt,n=in();
for(int i=1;i<=n;i++) Extend(),printf("%lld\n",ans);
return 0;
}

  

BZOJ 4516: [Sdoi2016]生成魔咒的更多相关文章

  1. BZOJ 4516&colon; &lbrack;Sdoi2016&rsqb;生成魔咒 &lbrack;后缀自动机&rsqb;

    4516: [Sdoi2016]生成魔咒 题意:询问一个字符串每个前缀有多少不同的子串 做了一下SDOI2016R1D2,题好水啊随便AK 强行开map上SAM 每个状态的贡献就是\(Max(s)-M ...

  2. BZOJ 4516&period; &lbrack;Sdoi2016&rsqb;生成魔咒【SAM 动态维护不同子串数量】

    [Sdoi2016]生成魔咒 动态维护不同子串的数量 想想如果只要查询一次要怎么做,那就是计算各个点的\(len[u]-len[link[u]]\)然后求和即可,现在要求动态更新,我们可以保存一个答案 ...

  3. 【刷题】BZOJ 4516 &lbrack;Sdoi2016&rsqb;生成魔咒

    Description 魔咒串由许多魔咒字符组成,魔咒字符可以用数字表示.例如可以将魔咒字符 1.2 拼凑起来形成一个魔咒串 [1,2]. 一个魔咒串 S 的非空字串被称为魔咒串 S 的生成魔咒. 例 ...

  4. ●BZOJ 4516 &lbrack;Sdoi2016&rsqb;生成魔咒

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=4516 题解: 把串反过来后,问题变为求每个后缀的互不相同的子串个数.首先用倍增算法求出 sa ...

  5. BZOJ 4516&colon; &lbrack;Sdoi2016&rsqb;生成魔咒 后缀自动机 性质

    http://www.lydsy.com/JudgeOnline/problem.php?id=4516 http://blog.csdn.net/doyouseeman/article/detail ...

  6. BZOJ 4516&colon; &lbrack;Sdoi2016&rsqb;生成魔咒——后缀数组、并查集

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4516 题意 一开始串为空,每次往串后面加一个字符,求本质不同的子串的个数,可以离线.即长度为 ...

  7. BZOJ&period;4516&period;&lbrack;SDOI2016&rsqb;生成魔咒&lpar;后缀数组 RMQ&rpar;

    题目链接 后缀自动机做法见这(超好写啊). 后缀数组是可以做的: 本质不同的字符串的个数为 \(子串个数-\sum_{ht[i]}\),即 \(\frac{n(n+1)}{2}-\sum_{ht[i] ...

  8. BZOJ&period;4516&period;&lbrack;SDOI2016&rsqb;生成魔咒&lpar;后缀自动机 map&rpar;

    题目链接 后缀数组做法见这. 直接SAM+map.对于每个节点其产生的不同子串数为len[i]-len[fa[i]]. //15932kb 676ms #include <map> #in ...

  9. BZOJ 4516 &lbrack;Sdoi2016&rsqb;生成魔咒 ——后缀自动机

    本质不同的字串,考虑SA的做法,比较弱,貌似不会. 好吧,只好用SAM了,由于后缀自动机的状态最简的性质, 所有不同的字串就是∑l[i]-l[fa[i]], 然后后缀自动机是可以在线的,然后维护一下就 ...

随机推荐

  1. 《SQL Server企业级平台管理实践》读书笔记——SQL Server中收缩数据库不好用的原因

    数据库管理员有时候需要控制文件的大小,可能选择收缩文件,或者把某些数据文件情况以便从数据库里删除. 这时候我们就要使用到DBCC SHRINKFILE命令,此命令的脚本为: DBCC SHRINKFI ...

  2. Distributed Sentence Similarity Base on Word Mover&&num;39&semi;s Distance

    Algorithm: Refrence from one ICML15 paper: Word Mover's Distance. 1. First use Google's word2vec too ...

  3. C&num;l连接OPC进行数据交互

    步骤 :引用 OPCNETAPI.DLL&&OPCNETAPI.COM.DLL 1.查询服务器      2. 连接服务器  3. 读取数据     4.写入数据 1.查询服务器 :根 ...

  4. Blob API及问题记录

    接上一篇<js创建下载文件>, 记录核心部分 Blob 的API, >>传送门 , 同时说下使用过程中碰到的一个问题. 先说问题: 用Blob创建后缀为.sql的文件, 内容是 ...

  5. 在egret中使用protobuf

    原文章删除,重新使用MarkDown排版 在H5游戏领域,对于服务端与客户端的通信协议有一个选择,那就是使用protobuf.js.对于那些直接使用JavaScript开发的引擎而言,protobuf ...

  6. &period;net core 2&period;0学习笔记(二):Hello World &amp&semi; 进阶

    官网已经有一个.net core的入手教程(https://www.microsoft.com/net/core#windowscmd),但这个教程完全没有顾及全宇宙第一IDE的感受.今天就跟大家体验 ...

  7. 关于js赋值给input解析

    <script type="text/javascript"> //关于js中取值问题 $(function(){ //定义function函数 var firstDa ...

  8. Spring的IOC原理

    1. IoC理论的背景 我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑. 图1:软件系统中耦合的对象 如果我们打开机 ...

  9. leetCodeReorderList链表合并

    原题 Given a singly linked list L: L0?L1?-?Ln-1?Ln, reorder it to: L0?Ln?L1?Ln-1?L2?Ln-2?- You must do ...

  10. cmake交叉编译android(转)

    生成cmake编译所需的文件 #-H指向CMakeLists.txt文件父级目录 #-B指向中间产物目录 #-DCMAKE_LIBRARY_OUTPUT_DIRECTORY指向so输出目录 #-DCM ...