【题目链接】

# 10038. 「一本通 2.1 练习 4」A Horrible Poem

【参考博客】

A Horrible Poem (字符串hash+数论)


【题目描述】

给出一个由小写英文字母组成的字符串 SS,再给出 qq 个询问,要求回答 SS 某个子串的最短循环节。
如果字符串 BB 是字符串 AA 的循环节,那么 AA 可以由 BB 重复若干次得到。

【算法】-首先对于长度为 lenlen 的子串,循环节长度为 xx 的充要条件:[1,len−x][1,len−x]串的哈希值等于 [x+1,len][x+1,len] 串的哈希值。

假设最短循环节长度为len则原串长度显然为len*k。若只考虑k,并且将k的质因数依次分解,每次试除k,则得到的k。k。和len的乘积仍是循环节,利用这个性质。依次用质因数 ii 试除n,若除去后仍是循环节,说明i属于k,将其除去,结果就留下了len。

【代码】:

 #include<cstdio>
#include<bitset>
#include<cstring>
#include<algorithm>
using namespace std;
typedef unsigned long long ULL ;
const int N = 5e5+;
ULL h[N],p[N],base = ; char str[N];
int n,m,len,ans,tmp,L,R; int prime[N],Min_p[N],cnt;
void Init(){
//memset( is_prime , true , sizeof is_prime );
int tot = ;
for(int i=;i<N;i++) {
if(!Min_p[i]) {
//if( i < 10 ) printf("%d\n",i);
prime[++tot]=i;
Min_p[i]=i;
}
for(int j=;j<=tot;j++) {
if(prime[j]>Min_p[i]||prime[j]*i>N) break;
Min_p[prime[j]*i]=prime[j];
}
}
cnt = tot ;
} void get_Hash(){
p[] = ;
for(int i=;i<=len;i++){
p[i] = p[i-] * base ;
h[i] = h[i-] * base + (ULL) str[i];
}
} bool Vaild( int L , int R , int k ){
return h[R] - h[L+k-] * p[len-k] == h[L + (len/k-)*k - ] - h[L-] * p[len-k] ;
}
int main()
{
Init();
//for(int i=1;i<10;i++) printf("%d\n",prime[i]);
scanf("%d%s%d",&n,str+,&m); len = strlen( str+ ) ;
get_Hash();
/*
for(int i=1;i<=len;i++){
printf("%llu\n",h[i]);
}
*/
while( m-- ){
scanf("%d%d",&L,&R);
len = tmp = ans = R - L + ;
while( tmp != ){
int k = Min_p[tmp] ;
while( tmp % k == && Vaild(L,R,ans/Min_p[tmp] ) )
tmp /= k , ans /= k ;
while( tmp % k == )
tmp /= k ;
}
printf("%d\n",ans);
}
return ;
}

【hash】A Horrible Poem的更多相关文章

  1. 【题解】A Horrible Poem

    题目大意 给出一个由小写英文字母组成的字符串 S,再给出 q 个询问,要求回答 S 某个子串的最短循环节. 如果字符串 B 是字符串 A 的循环节,那么 A 可以由 B 重复若干次得到. 输入格式 第 ...

  2. 【bzoj2795】【Poi2012】A Horrible Poem

    题解: 询问区间的整循环节 设区间长度为$n$ 如果有循环节长为$x$和$y$,那由斐蜀定理得$gcd(x,y)$也一定为一个循环节: 假设最小的循环节长为$mn$,那么对于任何循环节长$x$,一定$ ...

  3. 【hash】BZOJ3751-[NOIP2014]解方程

    [题目大意] 已知多项式方程:a0+a1*x+a2*x^2+...+an*x^n=0.求这个方程在[1,m]内的整数解(n和m均为正整数). [思路] *当年考场上怒打300+行高精度,然而没骗到多少 ...

  4. 【hash】Power Strings

    [题意]: 给出s串出来,能否找到一个前缀 ,通过多次前缀进行拼接.构成s串.如果有多个,请输出最多次数那个. 如:aaaa 可以用1个a,进行4次拼接 可以用2个a,进行2次拼接 可以用4个a,进行 ...

  5. 【hash】Similarity of Subtrees

    图片来源: https://blog.csdn.net/dylan_frank/article/details/78177368 [题意]: 对于每一个节点来说有多少对相同的子树. [题解]: 利用层 ...

  6. 【hash】Seek the Name, Seek the Fame

    [哈希和哈希表]Seek the Name, Seek the Fame 题目描述 The little cat is so famous, that many couples tramp over ...

  7. 【hash】Three friends

    [来源]:bzoj3916 [参考博客] BZOJ3916: [Baltic2014]friends [ 哈希和哈希表]Three Friends [Baltic2014][BZOJ3916]frie ...

  8. 湖南师范大学2018年大学生程序设计竞赛新生赛 A 齐神和心美的游戏【hash】

    [链接]:A [题意]:给你n个数的序列和k.判断是否可以三个数组成k(同一个数可以拿多次) [分析]:每个数vis记录一下.2层循环.两数之和不超过k以及剩下的数出现在序列中那么ok. [代码]: ...

  9. 【hash】珍珠

    [来源] https://loj.ac/problem/2427 [参考博客] LOJ#2427. 「POI2010」珍珠项链 Beads [题解]: 复杂度计算: 暴力枚举k每次计算是n/2+n/3 ...

随机推荐

  1. Linux网络编程五、套接字超时

    1.accept超时 accept等待并接受连接请求的过程是阻塞的,可以通过IO转接来设置等待一定的时长,如果超时没有连接,就让这个函数返回,让当前进程/线程处理别的任务. 例: // 最大的文件描述 ...

  2. Difference Between static and default methods in interface

    I was learning through interfaces when I noticed that you can now define static and default methods ...

  3. Spring+shiro session与线程池的坑

    在java web编程中,经常使用shiro来管理session,也确实好用 shiro来获取session的方式 SecurityUtils.getSubject().getSession() 其中 ...

  4. centos7下面改变亮度

    通过改自己的配置文件来改变亮度的方法在我的机器上面是不中用了,我的是台式机,我用的集成显卡,目前我找到的还勉强的方法就是通过安装redshift来改变屏幕的亮度,我就是不喜欢太亮,差点瞎了. 具体是这 ...

  5. swoole入门简介

    原文:https://www.cnblogs.com/dormscript/p/4811921.html 本文主要记录一下学习swoole的过程.填过的坑以及swoole究竟有多么强大! 首先说一下对 ...

  6. ubuntu16.04下如何安装dtc工具?

    答: sudo apt-get install device-tree-compiler -y

  7. OpenCL Workshop 1 —— 数字音频滤波

    Introduction 这两年深度学习大火,Cuda跟着吃红利,OpenCL发展也很快.虽然OpenCL不是事实上的标准,但是作为开放标准,适应性是很强的,除了显卡之外,CPU/FPGA上都可以执行 ...

  8. Mybatis中表名当做变量

    做业务时,有时候会遇到不同SQL语句之中,只有使用的表名不用而已,其他参数和取得值都是一样的情况.这种时候必然想到把表名当做一个变量传到共通的SQL语句中. 当然正常的传入参数的方式#{param}肯 ...

  9. vue项目报错:Unexpected tab character (no-tabs)

    eslint意思是检查规范代码 第一种方法: 新建项目的时候 第二种方法: 首先在项目的根目录下.eslintrc.js中加入一行代码:"no-tabs":"off&qu ...

  10. Linux 查看 MySQL的版本信息

    Linux 查看 MySQL的版本信息 如何查看某台 Linux 主机上的 安装的 MySQL版本信息? 使用如下命令,查看 MySQL的版本信息: mysql -V 或者 mysql --versi ...