/*
巧妙地使用fail数组
根据fail数组的定义
fail[i] 有 长度为i的子串最长公共前后缀为fail[i]
比如样例 fail 0 0 1 2
那么我们维护一个ans[i]表示到i位置的时候
前i位置子串的匹配次数
比如 a b a
ans[1]=1 ans[2]=1
到ans[3]的时候 发现 a 又出现了一边 说明之前的a子串统计少了
相应的可以根据 fail找到a的位置在统计一遍就不漏了
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 200010
using namespace std;
int T,an,ans[maxn],l,fail[maxn];
char s[maxn];
void kmp_init()
{
int p=;
for(int i=;i<=l;i++)
{
while(p&&s[p+]!=s[i])
p=fail[p];
if(s[p+]==s[i])
p++;
fail[i]=p;
}
}
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d",&l);
scanf("%s",s+);
an=;//初始化害死人
memset(ans,,sizeof(ans));
memset(fail,,sizeof(fail));
kmp_init();
for(int i=;i<=l;i++)
{
ans[i]=;
if(fail[i])//如果当前的子串存在公共前后缀
//说明这个公共缀之前统计少了
ans[i]+=ans[fail[i]];
an=(an+ans[i])%;
}
printf("%d\n",an);
}
}

HUD3336的更多相关文章

随机推荐

  1. Day13 SQLAlchemy连表操作和堡垒机

    一.数据库操作 1.创建表.插入数据和一对多查询 #!/usr/bin/env python # -*- coding: utf-8 -*- # Author: wanghuafeng from sq ...

  2. HDU 1207

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1207 四柱汉诺塔问题 当 r = (sqrt(8*n+1)-1)/2 时, 存在 count = (n ...

  3. bzoj1563: [NOI2009]诗人小G

    Description Input Output 对于每组数据,若最小的不协调度不超过1018,则第一行一个数表示不协调度若最小的不协调度超过1018,则输出"Too hard to arr ...

  4. emmet插件的导入与实用

    http://jingyan.baidu.com/article/ff4116259b057c12e48237b8.html http://www.iteye.com/news/27580 分享htm ...

  5. Java中的多线程总结(转)

      1.多线程概述 当一个程序运行时,内部可能包含了多个顺序执行流,每个顺序执行流就是一个线程.主要以下几个优点: 线程之间很容易实现共享内存 创建线程代价较小 Java语言内置多线程功能支持 2.线 ...

  6. 计算广义积分$$\int_0^{+\infty}\cos x^p {\rm d}x,\int_0^{+\infty}\sin x^p {\rm d}x, p>1$$

    ${\bf 解:}$ 在角状域$G=\{z\in\mathbb{C}|0<{\rm Arg}z<\frac{\pi}{2p}\}$上引入辅助函数$e^{iz^p}$, 其中$z^p=|z| ...

  7. Facebook IV Winner's Interview: 1st place, Peter Best (aka fakeplastictrees)

    Facebook IV Winner's Interview: 1st place, Peter Best (aka fakeplastictrees) Peter Best (aka fakepla ...

  8. Dollars

    uva147: 题意:给你几种钱币,在给你一个钱的数目,问有多少种用这些钱来组成这个数目. 题解:完全背包,不过此时要把钱的数目*100,因为是小数,背包的容量都是整数,然后dp,求出每个容量的数目即 ...

  9. MySql的大小写问题

    原来Linux下的MySQL默认是区分表名大小写的,通过如下设置,可以让MySQL不区分表名大小写:1.用root登录,修改 /etc/my.cnf:2.在[mysqld]节点下,加入一行: lowe ...

  10. 中国linux论坛

    linux在国内经过十多年的发展,已慢慢走向成熟.昔日如雨后春笋般成长的linux网站,现在已出现了明显的两极分化.一部分已成长壮大,公司化运作,一部分面临域名出售或关闭的境地.  以笔者经验,以下十 ...