题意:每次插入一个数字,查询本质不同的子串有多少个

题解:sam,数字很大,ch数组用map来存,每次ins之后查询一下新建点表示多少个本质不同的子串(l[np]-l[fa[np]])

  1. /**************************************************************
  2. Problem: 4516
  3. User: walfy
  4. Language: C++
  5. Result: Accepted
  6. Time:804 ms
  7. Memory:16600 kb
  8. ****************************************************************/
  9. //#pragma GCC optimize(2)
  10. //#pragma GCC optimize(3)
  11. //#pragma GCC optimize(4)
  12. //#pragma GCC optimize("unroll-loops")
  13. //#pragma comment(linker, "/stack:200000000")
  14. //#pragma GCC optimize("Ofast,no-stack-protector")
  15. //#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
  16. #include<bits/stdc++.h>
  17. #define fi first
  18. #define se second
  19. #define db double
  20. #define mp make_pair
  21. #define pb push_back
  22. #define pi acos(-1.0)
  23. #define ll long long
  24. #define vi vector<int>
  25. #define mod 1000000007
  26. #define ld long double
  27. #define C 0.5772156649
  28. #define ls l,m,rt<<1
  29. #define rs m+1,r,rt<<1|1
  30. #define pll pair<ll,ll>
  31. #define pil pair<int,ll>
  32. #define pli pair<ll,int>
  33. #define pii pair<int,int>
  34. //#define cd complex<double>
  35. #define ull unsigned long long
  36. #define base 1000000000000000000
  37. #define Max(a,b) ((a)>(b)?(a):(b))
  38. #define Min(a,b) ((a)<(b)?(a):(b))
  39. #define fin freopen("a.txt","r",stdin)
  40. #define fout freopen("a.txt","w",stdout)
  41. #define fio ios::sync_with_stdio(false);cin.tie(0)
  42. template<typename T>
  43. inline T const& MAX(T const &a,T const &b){return a>b?a:b;}
  44. template<typename T>
  45. inline T const& MIN(T const &a,T const &b){return a<b?a:b;}
  46. inline void add(ll &a,ll b){a+=b;if(a>=mod)a-=mod;}
  47. inline void sub(ll &a,ll b){a-=b;if(a<0)a+=mod;}
  48. inline ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
  49. inline ll qp(ll a,ll b){ll ans=1;while(b){if(b&1)ans=ans*a%mod;a=a*a%mod,b>>=1;}return ans;}
  50. inline ll qp(ll a,ll b,ll c){ll ans=1;while(b){if(b&1)ans=ans*a%c;a=a*a%c,b>>=1;}return ans;}
  51. using namespace std;
  52. const double eps=1e-8;
  53. const ll INF=0x3f3f3f3f3f3f3f3f;
  54. const int N=100000+10,maxn=100000+10,inf=0x3f3f3f3f;
  55. char s[N];
  56. ll ans=0;
  57. struct SAM{
  58. int last,cnt;
  59. int fa[N<<1],l[N<<1];
  60. map<int,int>ch[N<<1];
  61. int c[N<<1],a[N<<1];
  62. void ins(int c){
  63. int p=last,np=++cnt;last=np;l[np]=l[p]+1;
  64. for(;p&&!ch[p][c];p=fa[p])ch[p][c]=np;
  65. if(!p)fa[np]=1;
  66. else
  67. {
  68. int q=ch[p][c];
  69. if(l[p]+1==l[q])fa[np]=q;
  70. else
  71. {
  72. int nq=++cnt;l[nq]=l[p]+1;
  73. ch[nq]=ch[q];
  74. // memcpy(ch[nq],ch[q],sizeof(ch[q]));
  75. fa[nq]=fa[q];fa[q]=fa[np]=nq;
  76. for(;ch[p][c]==q;p=fa[p])ch[p][c]=nq;
  77. }
  78. }
  79. ans+=1ll*(l[np]-l[fa[np]]);
  80. }
  81. void build(){
  82. last=cnt=1;
  83. }
  84. }sam;
  85. int main()
  86. {
  87. sam.build();
  88. int n;scanf("%d",&n);
  89. for(int i=1;i<=n;i++)
  90. {
  91. int x;scanf("%d",&x);
  92. sam.ins(x);
  93. printf("%lld\n",ans);
  94. }
  95. return 0;
  96. }
  97. /********************
  98. ********************/

bzoj4516: [Sdoi2016]生成魔咒 sam的更多相关文章

  1. BZOJ4516: [Sdoi2016]生成魔咒 后缀自动机

    #include<iostream> #include<cstdio> #include<cstring> #include<queue> #inclu ...

  2. [Sdoi2016]生成魔咒[SAM or SA]

    4516: [Sdoi2016]生成魔咒 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1017  Solved: 569[Submit][Statu ...

  3. [bzoj4516][Sdoi2016]生成魔咒——后缀自动机

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

  4. BZOJ4516 [Sdoi2016]生成魔咒 【后缀自动机】

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

  5. BZOJ4516: [Sdoi2016]生成魔咒

    果然SA比SAM+map快~加了fread目前rank1. 首先这是SAM裸题,然而SA求本质不同子串个数也很容易.考虑倒着建SA,这样没错加一个字符就变成加一个后缀,其他后缀都不变,那么i的答案就是 ...

  6. BZOJ4516 SDOI2016生成魔咒(后缀数组+平衡树)

    一个字符串本质不同的子串数量显然是总子串数减去所有height值.如果一个个往里加字符的话,每次都会改动所有后缀完全没法做.但发现如果从后往前加的话,每次只会添加一个后缀.于是我们把字符串倒过来,每次 ...

  7. 2018.12.23 bzoj4516: [Sdoi2016]生成魔咒(后缀自动机)

    传送门 samsamsam入门题. 题意简述:给出一个串让你依次插入字符,求每次插入字符之后不同子串的数量. 显然每次的变化量只跟新出现的nnn个后缀有关系,那么显然就是maxlenp−maxlenl ...

  8. bzoj千题计划283:bzoj4516: [Sdoi2016]生成魔咒(后缀数组)

    http://www.lydsy.com/JudgeOnline/problem.php?id=4516 考虑在后面新加一个字母产生的影响 假设是第i个 如果不考虑重复,那么会增加i个不同的字符串 考 ...

  9. BZOJ4516: [Sdoi2016]生成魔咒(后缀数组 set RMQ)

    题意 题目链接 Sol 毒瘤SDOI 终于有一道我会做的题啦qwq 首先,本质不同的子串的个数 $ = \frac{n(n + 1)}{2} - \sum height[i]$ 把原串翻转过来,每次就 ...

随机推荐

  1. Linux/shell: Concatenate multiple lines to one line

    $ cat file START Unix Linux START Solaris Aix SCO 1. Join the lines following the pattern START with ...

  2. c# 进阶之 WebAPI

    REST是设计风格而不是标准. webapi有自己的路由. webservice和wcf的协议都是soap协议,数据的序列化和反序列化都是soap的格式.而webapi是Json的数据传递 webap ...

  3. P4720 【模板】扩展卢卡斯

    思路 扩展Lucas和Lucas定理其实没什么关系 我们要求的是这样的一个问题 \[ \left(\begin{matrix}n\\m\end{matrix}\right) mod\ P \] p不一 ...

  4. (zhuan) 大牛讲堂 | 算法工程师入门第二期-穆黎森讲增强学习

    大牛讲堂 | 算法工程师入门第二期-穆黎森讲增强学习 2017-07-13 HorizonRobotics

  5. SAP-批量修改主数据(客户、供应商、物料)

    SAP-批量修改主数据(客户.供应商.物料) TCODE: MASS 对于批量修改主数据如客户,供应商等,可以试用一下Mass , 它所能修改的范围如下: 选定要修改的对象后,点击运行,会要求选择需要 ...

  6. 51nod 1832 先序遍历与后序遍历(dfs+高精度)

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1832 题意: 思路: 官方题解如下: 可以看一下这篇文章:https:/ ...

  7. Go 灵活多变的切片Slice

    我们知道数组定义好之后其长度就无法再修改,但是,在实际开发过程中,有时候我们并不知道需要多大的数组,我们期望数组的长度是可变的, 在 Go 中有一种数据结构切片(Slice) 解决了这个问题,它是可变 ...

  8. QT读文件夹内所有文件名

    void monizhuzhan::filenameInDir() { //判断路径是否存在 QDir dir(path); if(!dir.exists()) return; //查看路径中后缀为. ...

  9. [原][osg]osgconv浅析

    查看osgconv.cpp main函数在533行 osg::ArgumentParser arguments(&argc,argv); //........一堆功能不管,先看一下文件读写 F ...

  10. 力扣(LeetCode)520. 检测大写字母

    给定一个单词,你需要判断单词的大写使用是否正确. 我们定义,在以下情况时,单词的大写用法是正确的: 全部字母都是大写,比如"USA". 单词中所有字母都不是大写,比如"l ...