【SPOJ】Distinct Substrings

求不同子串数量

统计每个点有效的字符串数量(第一次出现的)

\(\sum\limits_{now=1}^{nod}now.longest-parents.longest\)

My complete code

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL maxn=3000;
LL nod,last,n,T;
LL len[maxn],fail[maxn],son[maxn][26];
char s[maxn];
inline void Insert(LL c){
LL np=++nod,p=last;
len[np]=len[p]+1;
last=np;
while(p&&!son[p][c]){
son[p][c]=np,
p=fail[p];
}
if(!p)
fail[np]=1;
else{
LL q=son[p][c];
if(len[q]==len[p]+1)
fail[np]=q;
else{
LL nq=++nod;
len[nq]=len[p]+1;
fail[nq]=fail[q];
memcpy(son[nq],son[q],sizeof(son[q]));
fail[np]=fail[q]=nq;
while(p&&son[p][c]==q){
son[p][c]=nq,
p=fail[p];
}
}
}
}
int main(){
scanf("%lld",&T);
while(T--){
memset(son,0,sizeof(son));
nod=last=1;
scanf(" %s",s);
for(LL i=0;i<strlen(s);++i)
Insert(s[i]-'A');
LL ans=0;
for(LL i=1;i<=nod;++i)
ans+=len[i]-len[fail[i]];
printf("%lld\n",ans);
}
return 0;
}

最新文章

  1. 深入理解java中的ArrayList和LinkedList
  2. .net程序部署(setupFactory)
  3. Linux中MySQL的基本操作
  4. GridView控件RowDataBound事件中获取列字段途径
  5. PHP 计算每个月的最后一天
  6. expect安装去测试
  7. Java [Leetcode 104]Maximum Depth of Binary Tree
  8. 问题-[DelphiXE2]编译程序体积大的问题
  9. AnonymousType匿名类型和对象之间的转换
  10. Subsets II 解答
  11. A+B II
  12. 谁说程序员都是苦逼的——看看兄弟连上海S2班的点点滴滴
  13. poj 1948 Triangular Pastures 小结
  14. 在ssm框架中前后台数据交互均使用json格式
  15. mysql中describe关键字
  16. day30 __hash__ 计算哈希值
  17. NYOJ 35 表达式求值
  18. 用Executors工具类创建线程池
  19. 【win7 + win server 2008】设置定时任务,设置.bat 文件去执行php脚本 == 用来配合爬虫程序简直不要太爽
  20. Web服务器和应用服务器简介

热门文章

  1. opencv Cascade Classifier Training中 opencv_annotation命令
  2. 记一次有趣的tp5代码执行
  3. Pandas-高级部分及其实验
  4. Thymeleaf 模板
  5. jmeter安装,汉化
  6. sed 查询特定内容
  7. nginx 之 https 证书配置
  8. Windows 如何录屏
  9. Gitlab-CI +Docker + Docker-Compose构建可持续集成java项目的镜像
  10. DNS服务——服务端 和 客户端 配置