【题目链接】 http://acm.hdu.edu.cn/showproblem.php?pid=4436

【题目大意】

  给出一些字符串,由0~9组成,求出所有不同子串的和。

【题解】

  将所有字符串添加拼接符10连接在一起建立自动机,
  从起点开始遍历所有节点,就能计算所有的子串和了。注意转移的时候只转移0到9节点。

【代码】

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
const int N=200005,mod=2012;
char s[N];
int n;
struct sam{
int p,q,np,nq,cnt,last,a[N][11],l[N],f[N];
sam(){cnt=0;last=++cnt;}
void init(){
cnt=0;last=++cnt;
memset(a,0,sizeof(a));
memset(l,0,sizeof(l));
memset(f,0,sizeof(f));
memset(b,0,sizeof(b));
memset(x,0,sizeof(x));
memset(sum,0,sizeof(sum));
memset(t,0,sizeof(t));
}
void extend(int c){
p=last;np=last=++cnt;l[np]=l[p]+1;
while(!a[p][c]&&p)a[p][c]=np,p=f[p];
if(!p)f[np]=1;
else{
q=a[p][c];
if(l[p]+1==l[q])f[np]=q;
else{
nq=++cnt;l[nq]=l[p]+1;
memcpy(a[nq],a[q],sizeof(a[q]));
f[nq]=f[q]; f[np]=f[q]=nq;
while(a[p][c]==q)a[p][c]=nq,p=f[p];
}
}
}int b[N],x[N];
void build(){
int len=0;
while(n--){
scanf("%s",s);
for(int i=0;s[i];i++)len++,extend(s[i]-'0');
extend(10),len++;
}for(int i=1;i<=cnt;i++)b[l[i]]++;
for(int i=1;i<=len;i++)b[i]+=b[i-1];
for(int i=1;i<=cnt;i++)x[b[l[i]]--]=i;
}int sum[N],t[N];
int solve(){
int ans=0;
sum[1]=0; t[1]=1;
for(int i=1;i<=cnt;i++){
int p=x[i];
for(int j=0;j<10;j++){
if(i==1&&j==0)continue;
if(a[p][j]){
q=a[p][j];
t[q]=(t[p]+t[q])%mod;
sum[q]=(sum[q]+sum[p]*10+t[p]*j)%mod;
}
}ans=(ans+sum[p])%mod;
}return ans;
}
}sam;
int main(){
while(~scanf("%d",&n)){
sam.init();
sam.build();
printf("%d\n",sam.solve());
}return 0;
}

  

最新文章

  1. JAVA内部类有关
  2. Java 文档注释
  3. javascript动态添加本地文件列表信息
  4. PHP基本知识
  5. vm内核参数优化设置
  6. 【h5-egret】深入浅出对象池
  7. Main()方法
  8. Linux下嗅探密码拿下服务器(转自MSX)
  9. myeclipse 解决没有自动提示
  10. Fix an “Unapproved Caller” SecurityAgent Message in Mac OS X
  11. 菜鸟学习spring IOC有感
  12. 使用protobuf编写配置文件以及读写
  13. Windows Server 2016-部署RODC只读域控制器
  14. TypeScript入门知识四(表达式和循环)
  15. 你不知道的JavaScript--Item23 定时器的合理使用
  16. js调用百度地图接口绘制任意多边形并获取每个点的经纬度等
  17. Tree Restoration Gym - 101755F (并查集)
  18. android nostra13
  19. input 内容改变的触发事件
  20. NOI.AC NOIP模拟赛 第六场 游记

热门文章

  1. [置顶] boost使用(六)
  2. 区分IE9/IE8/IE7/IE6及其他浏览器-CSS hack
  3. Critical Log Review Checklist for Security Incidents
  4. 不要将 Array、Object 等类型指定给 prototype
  5. java实现二维码生成的几个方法
  6. 转载文章:Windows Azure 七月份更新:SQL 数据库、流量管理器、自动伸缩、虚拟机
  7. Spring单例与线程安全小结
  8. poj1547---结构数组
  9. Android Intent的几种用法总结【转】
  10. javascript 的加载方式