bzoj 3238: [Ahoi2013]差异 -- 后缀数组
3238: [Ahoi2013]差异
Time Limit: 20 Sec Memory Limit: 512 MB
Description
Input
一行,一个字符串S
Output
一行,一个整数,表示所求值
Sample Input
Sample Output
HINT
2<=N<=500000,S由小写英文字母组成
Source
后缀数组+单调栈水过。。。
- #include<map>
- #include<cmath>
- #include<queue>
- #include<cstdio>
- #include<cstring>
- #include<iostream>
- #include<algorithm>
- using namespace std;
- #define inf 1000000007
- #define ll long long
- #define N 500010
- int v[N],rk1[N],rk2[N],sa1[N],sa2[N],n,a[N],ht[N];
- int l[N],r[N],q[N],tot;
- int *sa=sa1,*SA=sa2,*rk=rk1,*RK=rk2;
- char s[N];
- ll ans;
- int main()
- {
- scanf("%s",s+);
- n=strlen(s+);
- for(int i=;i<=n;i++){a[i]=s[i]-'a'+;v[a[i]]++;}
- for(int i=;i<=;i++) v[i]+=v[i-];
- for(int i=n;i;i--) sa[v[a[i]]--]=i;
- for(int i=;i<=n;i++) rk[sa[i]]=rk[sa[i-]]+(a[sa[i]]!=a[sa[i-]]);
- for(int k=;k<=n;k<<=)
- {
- for(int i=;i<=n;i++) v[rk[sa[i]]]=i;
- for(int i=n;i;i--) if(sa[i]>k) SA[v[rk[sa[i]-k]]--]=sa[i]-k;
- for(int i=n-k+;i<=n;i++) SA[v[rk[i]]--]=i;
- for(int i=;i<=n;i++) RK[SA[i]]=RK[SA[i-]]+(rk[SA[i]]!=rk[SA[i-]]||rk[SA[i]+k]!=rk[SA[i-]+k]);
- swap(sa,SA);swap(rk,RK);
- }
- int k=,j;
- for(int i=;i<n;i++)
- {
- j=sa[rk[i]-];
- while(s[i+k]==s[j+k]) k++;
- ht[rk[i]]=k;
- if(k) k--;
- }
- ht[]=-inf;
- for(int i=;i<=n;i++)
- {
- while(ht[i]<=ht[q[tot]]) tot--;
- l[i]=q[tot]+; q[++tot]=i;
- }
- ht[n+]=-inf;tot=;q[]=n+;
- for(int i=n;i;i--)
- {
- while(ht[i]<ht[q[tot]]) tot--;
- r[i]=q[tot]-; q[++tot]=i;
- }
- ans=(ll)(n+)*n*(n-)/;
- for(int i=;i<=n;i++) ans-=2LL*(i-l[i]+)*(r[i]-i+)*ht[i];
- printf("%lld\n",ans);
- return ;
- }
bzoj 3238: [Ahoi2013]差异 -- 后缀数组的更多相关文章
- BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2326 Solved: 1054[Submit][Status ...
- BZOJ 3238: [Ahoi2013]差异 [后缀自动机]
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2512 Solved: 1140[Submit][Status ...
- BZOJ.3238.[AHOI2013]差异(后缀自动机 树形DP/后缀数组 单调栈)
题目链接 \(Description\) \(Solution\) len(Ti)+len(Tj)可以直接算出来,每个小于n的长度会被计算n-1次. \[\sum_{i=1}^n\sum_{j=i+1 ...
- BZOJ 3238: [Ahoi2013]差异 后缀自动机 树形dp
http://www.lydsy.com/JudgeOnline/problem.php?id=3238 就算是全局变量,也不要忘记,初始化(吐血). 长得一副lca样,没想到是个树形dp(小丫头还有 ...
- BZOJ 3238 [Ahoi2013]差异 ——后缀自动机
后缀自动机的parent树就是反串的后缀树. 所以只需要反向构建出后缀树,就可以乱搞了. #include <cstdio> #include <cstring> #inclu ...
- bzoj 3238 Ahoi2013 差异
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2357 Solved: 1067[Submit][Status ...
- ●BZOJ 3238 [Ahoi2013]差异
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3238 题解: 后缀数组套路深. 问题转化为求出任意两个后缀的LCP之和 在计算贡献时,各种不 ...
- BZOJ 3238: [Ahoi2013]差异((单调栈+后缀数组)/(后缀树))
[传送门[(https://www.lydsy.com/JudgeOnline/problem.php?id=3238) 解题思路 首先原式可以把\(len\)那部分直接算出来,然后通过后缀数组求\( ...
- 【BZOJ3238】[Ahoi2013]差异 后缀数组+单调栈
[BZOJ3238][Ahoi2013]差异 Description Input 一行,一个字符串S Output 一行,一个整数,表示所求值 Sample Input cacao Sample Ou ...
随机推荐
- hdu 3729 I'm Telling the Truth(二分匹配_ 匈牙利算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3729 I'm Telling the Truth Time Limit: 2000/1000 MS ( ...
- 生成验证码tp
js里拼接随机数 页面上链接 去掉后缀名
- [转载]Android中Bitmap和Drawable
一.相关概念 1.Drawable就是一个可画的对象,其可能是一张位图(BitmapDrawable),也可能是一个图形(ShapeDrawable),还有可能是一个图层(LayerDrawable) ...
- CTF线下赛AWD套路小结
近打了2场CTF线下赛,把AWD模式中的一些小套路做一些总结,本人web狗,二进制部分就不班门弄斧了. 一. AWD模式简介 AWD:Attack With Defence,比赛中每个队伍维护多台服务 ...
- css预处理scss环境配置
css 预处理器 CSS 预处理器用一种专门的编程语言,进行 Web css编码,然后再编译成正常的 CSS 文件,以供项目使用:说简单点就是在某个环境下写css 可以写变量.表达式.嵌套等,在通过该 ...
- NTP算法
网络时间协议 由特拉华大学的David L. Mills热心提供.http://www.eecis.udel.edu/~mills mills@udel.edu 由Reinhard v. Hanxle ...
- #include<stdarg.h> 可变参数使用
今天上计算方法这课时觉得无聊至极,于是拿出C++编程之道来看了看..无意之中看到了#include<stdarg.h> va_list,va_start,va_end等东西,不知是怎么用的 ...
- Kiggle:Digit Recognizer
题目链接:Kiggle:Digit Recognizer Each image is 28 pixels in height and 28 pixels in width, for a total o ...
- js + -操作符
js + 举例说明最有效了... "11"+1='111' "11"+'1'="111" 11+1=12 大概的感觉就是+操作符会优先输入S ...
- Python 读写xlsx
# pip install openpyxl # openpyxl只能用于处理xlsx,不能用于处理xlsfrom openpyxl import load_workbook # 打开文件ExcelF ...