• 题解:

    • 分块对每个块的起点$st[i]$到$n$做一次回文自动机;
    • 由于子串的回文自动机是原串的子图,所以并不需要重新构图,在原来的图上做即可;
    • 做的时候记录某个终点的本质不同的回文串和$sum[i][r]$
    • 对于询问$[l,r]$,直接统计$l$后的整块,考虑统计$l$所在的散块$[l,st[i]]$
    • 根据回文串的对称性,可以预处理出在$st[i]$匹配的最长回文后缀节点,所以从st[i]到l暴力即可;
    • 注意判断是否重复和是否超出边界;
    • 暂时还不会两个log的做法;
    •  #include<bits/stdc++.h>
      #define rg register
      using namespace std;
      const int M=,N=;
      int T,n,m,typ,sz,ch[N][],Fl[N][],fl[N],end[M][N],pos[M][N];
      int sum[M][N],u,tot,bl[N],st[N],ed[N],lst,vis[N],len[N],s[N];
      inline char gc(){
      static char*p1,*p2,buf[];
      if(p1==p2)p2=(p1=buf)+fread(buf,,,stdin);
      return(p1==p2)?EOF:*p1++;
      }
      inline int rd(){
      int x=;char c=gc();
      while(c<''||c>'')c=gc();
      while(c>=''&&c<='')x=(x<<)+(x<<)+c-'',c=gc();
      return x;
      }
      void extend1(int l,int i){
      int x=lst;
      if(i-len[x]-<l||s[i-len[x]-]!=s[i])x=Fl[x][s[i]];
      if(!ch[x][s[i]]){
      len[++sz]=len[x]+;
      int y=fl[x];
      if(s[i-len[y]-]!=s[i])y=Fl[y][s[i]];y=ch[y][s[i]];
      memcpy(Fl[sz],Fl[y],sizeof(Fl[y]));
      Fl[sz][s[i-len[y]]]=fl[sz]=y;
      ch[x][s[i]]=sz;
      }
      lst=x=ch[x][s[i]];
      }
      void extend2(int i,int r){
      int x=lst;
      if(i+len[x]+>r||s[i+len[x]+]!=s[i])x=Fl[x][s[i]];
      if(!ch[x][s[i]]){
      len[++sz]=len[x]+;
      int y=fl[x];
      if(s[i+len[y]+]!=s[i])y=Fl[y][s[i]];y=ch[y][s[i]];
      memcpy(Fl[sz],Fl[y],sizeof(Fl[y]));
      Fl[sz][s[i+len[y]]]=fl[sz]=y;
      ch[x][s[i]]=sz;
      }
      lst=x=ch[x][s[i]];
      }
      int main(){
      #ifndef ONLINE_JUDGE
      freopen("loj6070.in","r",stdin);
      freopen("loj6070.out","w",stdout);
      #endif
      typ=rd();n=rd();m=rd();
      u = sqrt(n);
      char c=gc();while(!isalpha(c))c=gc();
      for(int i=;i<=n;++i,c=gc()){
      bl[i]=(i-)/u+;ed[bl[i]]=i;
      if(!st[bl[i]])st[bl[i]]=i;
      s[i]=c-'a';
      }tot=bl[n];
      sz=;
      fl[]=;fl[]=;
      len[]=;len[]=-;
      for(rg int i=;i<;++i)Fl[][i]=;
      memset(end,0x3f,sizeof(end));
      for(rg int i=;i<=tot;++i){
      lst=;T++;
      for(rg int j=st[i];j<=n;++j){
      extend1(st[i],j);
      sum[i][j]=sum[i][j-];
      if(vis[lst]<T){
      vis[lst]=T;
      sum[i][j]++;
      end[i][lst]=j;
      }
      if(len[lst]==j-st[i]+)pos[i][j]=lst;
      else pos[i][j]=pos[i][j-];
      }
      }
      int ans=;
      for(rg int i=,l,r;i<=m;++i){
      T++;
      l=rd();r=rd();
      if(typ)l^=ans,r^=ans;
      if(bl[l]==bl[r]){
      lst=;ans=;
      for(rg int j=l;j<=r;++j){
      extend1(l,j);
      if(vis[lst]<T)vis[lst]=T,ans++;
      }
      }else{
      ans=sum[bl[l]+][r];
      lst=pos[bl[l]+][r];
      for(rg int j=ed[bl[l]];j>=l;--j){
      extend2(j,r);
      if(vis[lst]<T&&end[bl[l]+][lst]>r)vis[lst]=T,ans++;
      }
      }
      printf("%d\n",ans);
      }
      return ;
      }

      loj6070

loj6070【山东集训第一轮Day4】基因的更多相关文章

  1. 【考试记录】2018 山东省队集训第一轮D4(雾)

    T1题意: 给你一个$n\times m$的矩阵$B$,求它能由最少多少个形如两个向量之积$(n\times 1)\times(1\times m)$的矩阵相加得到. 题解: 考虑上界,最多需要$mi ...

  2. 上海市2019年公务员录用考试第一轮首批面试名单(B类)

    上海市2019年公务员录用考试第一轮首批面试名单(B类) 2019-03-12 设置字体:大 中 小 职位序号 注册编号 职位序号 注册编号 职位序号 注册编号 职位序号 注册编号 1910565 5 ...

  3. 上海市2019年公务员录用考试第一轮首批面试名单(A类)

    上海市2019年公务员录用考试第一轮首批面试名单(A类) 注册编号 总成绩 注册编号 总成绩 注册编号 总成绩 注册编号 总成绩 4016574 127.4 5112479 145.9 5125732 ...

  4. 玩下软工项目,第一轮--全局Context的获取,SQLite的建立与增删改查,读取用户通话记录信息

    项目的Github地址:https://github.com/ggrcwxh/LastTime 采用基于git的多人协作开发模式 软件采用mvc设计模式,前端这么艺术的事我不太懂,交给斌豪同学去头疼了 ...

  5. STL 入门 (17 暑假集训第一周)

    快速全排列的函数 头文件<algorithm> next_permutation(a,a+n) ---------------------------------------------- ...

  6. Postmortem Report 第一轮迭代事后分析报告

    一.设想和目标 1.1 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件<BlueZ>是一款全新动作类塔防游戏.与市面上已经存在的塔防游戏不同 ...

  7. SDOI2017第一轮

    本蒟蒻表示终于$AC$了$SDOI2017\text{第一轮}$! 兴奋! 附上各个题的题解: $DAT1$: $T1$: BZOJ4816: [Sdoi2017]数字表格 $T2$: BZOJ481 ...

  8. 史上最全的CSP-J/S 第一轮知识点

    CSP-J/S 第一轮知识点选讲 \(NOIP\)(全国青少年信息学奥林匹克竞赛)于2019年取消.取而代之的是由\(CCF\)推出的非专业级软件能力认证,也就是现在的\(CSP-J/S\).作为一名 ...

  9. it's over | 2019 CSP-S 第一轮认证

    不知道自己有没有凉,毕竟我们省这么弱(据说有的省80都悬... 其实这几天对初赛基本没什么感觉,可能是没给自己多大压力吧,倒是班上的一群同学似乎比我们还着急,我们的数学课代表兼数竞大佬特意给我画了吉祥 ...

随机推荐

  1. ubuntu下import matplotlib错误解决办法

    环境:ubuntu16.04,python2.7,tensorflow1.4.0 问题: ImportError: No moudule named _tkinter, please install ...

  2. Mysql Order By注入总结

    何为order by 注入 本文讨论的内容指可控制的位置在order by子句后,如下order参数可控"select * from goods order by $_GET['order' ...

  3. chage命令详解

    基础命令学习目录首页 原文链接:https://www.jb51.net/article/78693.htm linux chage命令简介: chage命令用于密码实效管理,该是用来修改帐号和密码的 ...

  4. Python发送邮件(最全)

    简单邮件传输协议(SMTP)是一种协议,用于在邮件服务器之间发送电子邮件和路由电子邮件. Python提供smtplib模块,该模块定义了一个SMTP客户端会话对象,可用于使用SMTP或ESMTP侦听 ...

  5. python数据分析画图体验

    对于numpy的函数,pands等,不是很熟,我来copy一下code,敲击一下,找找感觉. 默认的导入包import numpy as npimport matplotlib.pyplot as p ...

  6. Vue 列表渲染及条件渲染实战

    条件渲染 有时候我们要根据数据的情况,决定标签是否进行显示或者有其他动作.最常见的就是,表格渲染的时候,如果表格没有数据,就显示无数据.如果有数据就显示表格数据. Vue 帮我们提供了一个v-if的指 ...

  7. Scrum Meeting 11 -2014.11.17

    今天和其他两个小组讨论了关于整合问题,在数据库连接等具体方面上还需要继续商讨. 我们小组内部讨论了,这周还是需要在处理整合的同时做项目整体的测试与改进的. Member Today’s task Ne ...

  8. 2018软工实践—Beta冲刺(4)

    队名 火箭少男100 组长博客 林燊大哥 作业博客 Beta 冲鸭鸭鸭! 成员冲刺阶段情况 林燊(组长) 过去两天完成了哪些任务 协调组内工作 完成软件开发技术文稿 展示GitHub当日代码/文档签入 ...

  9. 团队作业4——第一次项目冲刺(Alpha版本)2017.11.16

    1.当天站立式会议照片 本次会议在5号公寓3楼召开,本次会议内容:①:熟悉每个人想做的模块.②:根据老师的要求将项目划分成一系列小任务.③:在上次会议内容完成的基础上增加新的任务. 2.每个人的工作 ...

  10. 22_IO_第22天(File、递归)_讲义

    今日内容介绍 1.File 2.递归 xmind:下载地址: 链接:https://pan.baidu.com/s/1Eaj9yP5i0x4PiJsZA4StQg 密码:845a 01IO技术概述 * ...