【bzoj2795】【Poi2012】A Horrible Poem

  • 题解:

    • 询问区间的整循环节
    • 设区间长度为$n$
    • 如果有循环节长为$x$和$y$,那由斐蜀定理得$gcd(x,y)$也一定为一个循环节;
    • 假设最小的循环节长为$mn$,那么对于任何循环节长$x$,一定$mn | x$ , 否则$gcd(mn,x)<mn$矛盾
    • 推出$\frac{n}{x} | \frac{n}{mn}$
    • 所以每次提出$n$的一个质因子$p$,考虑是否可以分成$p$段,如果可以$n=\frac{n}{p}$继续找;
    • 最后得出来的$n$就是最短的循环节;
    • 分解质因子可以$O(n)$线筛最大/最小质因子,$O(logn)$分解;
    •  1 #include<bits/stdc++.h>
       2 #define rg register
       3 #define il inline
       4 #define ull unsigned long long
       5 #define base 1234567891
       6 using namespace std;
       7 const int N=500010;
       8 int vis[N],pr[N],pt,v[N],n,m,len;
       9 ull pw[N],h[N];
      10 char gc(){
      11     static char*p1,*p2,s[1000000];
      12     if(p1==p2)p2=(p1=s)+fread(s,1,1000000,stdin);
      13     return(p1==p2)?EOF:*p1++;
      14 }
      15 int rd(){
      16     int x=0;char c=gc();
      17     while(c<‘0‘||c>‘9‘)c=gc();
      18     while(c>=‘0‘&&c<=‘9‘)x=(x<<1)+(x<<3)+c-‘0‘,c=gc();
      19     return x;
      20 }
      21 void pre(){
      22     for(rg int i=2;i<=n;i++){
      23         if(!vis[i])pr[++pt]=i,v[i]=i;
      24         for(rg int j=1,t;j<=pt&&pr[j]*i<=n;j++){
      25             vis[t=i*pr[j]]=1;
      26             v[t]=pr[j];
      27             if(i%pr[j]==0)break;
      28         }
      29     }
      30 }
      31 ull cal(int i,int j){return h[i+j-1] - h[i-1]*pw[j];}
      32 int main(){
      33     #ifndef ONLINE_JUDGE
      34     freopen("bzoj2795.in","r",stdin);
      35     freopen("bzoj2795.out","w",stdout);
      36     #endif
      37     n=rd(); pre();
      38     char ch=gc();while(!isalpha(ch))ch=gc();
      39     for(rg int i=pw[0]=1;i<=n;i++,ch=gc()){
      40         h[i]=h[i-1]*base+ch;
      41         pw[i]=pw[i-1]*base;
      42     }
      43     m=rd();
      44     for(rg int i=1,l,r;i<=m;i++){
      45         l=rd(); r=rd();
      46         int ans=r-l+1,now=ans,t;
      47         while(now>1){
      48             t=ans/v[now];
      49             if(cal(l,ans-t)==cal(l+t,ans-t))ans/=v[now];
      50             now/=v[now];
      51         }
      52         printf("%d\n",ans);
      53     }
      54     return 0;
      55 }

      bzoj2795

原文地址:https://www.cnblogs.com/Paul-Guderian/p/10241556.html

时间: 2024-10-10 16:47:20

【bzoj2795】【Poi2012】A Horrible Poem的相关文章

【BZOJ2795】[Poi2012]A Horrible Poem hash

[BZOJ2795][Poi2012]A Horrible Poem Description 给出一个由小写英文字母组成的字符串S,再给出q个询问,要求回答S某个子串的最短循环节.如果字符串B是字符串A的循环节,那么A可以由B重复若干次得到. Input 第一行一个正整数n (n<=500,000),表示S的长度.第二行n个小写英文字母,表示字符串S.第三行一个正整数q (q<=2,000,000),表示询问个数.下面q行每行两个正整数a,b (1<=a<=b<=n),表示询

【Windows10&nbsp;IoT开发系列】配置篇

原文:[Windows10 IoT开发系列]配置篇 Windows10 For IoT是Windows 10家族的一个新星,其针对不同平台拥有不同的版本.而其最重要的一个版本是运行在Raspberry Pi.MinnowBoard和Galileo平台上的核心版.本文重点针对Raspberry Pi平台的Windwos10 IoT配置做介绍. Windows 10 IoT Editions ​一:设置你的电脑. 注:​开发Windows10 IoT的电脑需要Visual Studio 2015.

【Windows10&nbsp;IoT开发系列】PowerShell的相关配置

原文:[Windows10 IoT开发系列]PowerShell的相关配置 可使用 Windows PowerShell 远程配置和管理任何 Windows 10 IoT 核心版设备.PowerShell 是基于任务的命令行 Shell 和脚本语言,专为进行系统管理而设计. 1.​启动 PowerShell (PS) 会话 注:若要使用装有Windows10 IoT Core设备启动PS会话,首先需要在主机电脑与设备之间创建信任关系. ​启动 Windows IoT 核心版设备后,与该设备相连的

【Windows10&nbsp;IoT开发系列】API&nbsp;移植工具

原文:[Windows10 IoT开发系列]API 移植工具 Windows 10 IoT Core 中是否提供你的当前 Win32 应用程序或库所依赖的 API? 如果不提供,是否存在可使用的等效 API? 此工具可以为你回答这些问题,并协助你将你的当前 Win32 应用程序和库迁移到 Windows IoT Core. Windows 10 IoT 核心版 API 移植工具可在 ms-iot/iot-utilities github 存储库中找到.下载存储库 zip 并将 IoTAPIPor

【Windows10&nbsp;IoT开发系列】“Hello,World!”指导

原文:[Windows10 IoT开发系列]"Hello,World!"指导 本文主要是介绍使用C#来开发一个可以运行在Raspberry Pi2上的一个基本项目. ​1.在启动Visual Studio 2015后,选择"文件"→"新建项目". ​在打开的"新建项目"对话框中,选择"通用". ​选择第一个项目"空白应用(通用Windows)" 新建项目 ​注:如果这是你创建的第一个项

【opencv入门之二】感兴趣区域ROI,线性混合addWeighted

参考网站: http://blog.csdn.net/poem_qianmo/article/details/20911629 1.感兴趣区域ROI //[2]定义一个Mat类型并给其设定ROI区域 Mat imageROI = srcImage1( Rect(200, 250, logoImage.cols, logoImage.rows )); //[3]加载掩摸(必须是灰度图) Mat mask = imread( "dota_logo.jpg", 0 ); //[4]将掩摸拷贝

【Windows10&nbsp;IoT开发系列】Powershell命令行实用程序

原文:[Windows10 IoT开发系列]Powershell命令行实用程序 更新帐户密码: 强烈建议你更新默认的管理员帐户密码.若要更新帐户密码,你可以发出以下命令: net user Administrator [new password]​ (其中 [new password] 表示你选择的强密码). 创建本地用户帐户: 如果你想要授予其他人访问你的 Windows IoT Core 设备的权限,你可以通过在 net user [username] [password] /add​ 中键

【python之路35】网络编程之socket相关

Socket socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. socket起源于Unix,而Unix/Linux基本哲学之一就是"一切皆文件",对于文件用[打开][读写][关闭]模式来操作.socket就是该模式的一个实现,socket即是一种特殊的文件,一些socket函数就是对其进行的操作(读/写IO.打开.关闭) socket和file的区别: fil

【ASP.NET实战教程】ASP.NET实战教程大集合,各种项目实战集合

[ASP.NET实战教程]ASP.NET实战教程大集合,各种项目实战集合,希望大家可以好好学习教程中,有的比较老了,但是一直很经典!!!!论坛中很多小伙伴说.net没有实战教程学习,所以小编连夜搜集整理出一些比较好的教程,望君好好珍惜,资源不易,且保持,且珍惜直接上资源截图: 下载地址[回复可见]:http://www.fu83.cn/thread-282-1-1.html 感觉文章写的好,一定要回复 推荐哦!!!

20150218【改进Poll定时查询】IMX257实现GPIO-IRQ中断按键获取键值驱动程序

[改进Poll定时查询]IMX257实现GPIO-IRQ中断按键获取键值驱动程序 2015-02-18 李海沿 按键驱动程序中,如果不使用read函数中使程序休眠的,而是还是使用查询方式的话,可以使用Poll函数,来控制一定时间内,如果有按键发生,则立即返回键值. 同时,poll也可以同时监控多个(比如说按键,鼠标,等)一旦发生事件则立即返回. 我们在linux查看帮助: 从帮助中的说明得知, poll, ppoll - wait for some event on a file descrip