Description

​ 如果某个串可以由两个一样的串前后连接得到,我们就称之为“偶串”。比如说“xyzxyz”和“aaaaaa”是偶串,而“ababab”和“xyzxy”则不是偶串。

​ 对于一个非空串SS,我们定义f(S)f(S)是在SS后面添加一些字符得到的最短偶串。比如f(f('abaaba')=)='abaababaab'。容易证明,对于一个非空串SS,f(S)f(S)是唯一的

​ 现在给定一个由小写英文字母构成的偶串SS,你需要求出f10100(S)f10100(S),并统计计算结果的第ll个字符到第rr个字符中,每个字母出现了多少次

​ 其中,f10100(S)f10100(S)是指f(f(f(...f(S)...)))f(f(f(...f(S)...))),式子中共有1010010100个ff

Input

第一行输入串SS

第二行两个数l,rl,r

Output

对于每个字母,输出一个数字表示答案,两个数字之间应有一个空格

Sample Input

Sample #1
abaaba
6 10 Sample #2
xx
1 1000000000000000000 Sample #3
vgxgpuamkvgxgvgxgpuamkvgxg
1 1000000000000000000

Sample Output

Sample #1
3 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Sample #2
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1000000000000000000 0 0 Sample #3
87167725689669676 0 0 0 0 0 282080685775825810 0 0 0 87167725689669676 0 87167725689669676 0 0 87167725689669676 0 0 0 0 87167725689669676 141040342887912905 0 141040342887912905 0 0

HINT

2≤|S|≤2×10^5

1≤l≤r≤10^18

本题采用subtask。

  • 存在30%的数据,满足|S|≤20
  • 存在50%的数据,满足|S|≤200

Sol

对于一个串,我们设为“SS”,它的最短周期为“T"(也就是S由T循环组成且最后一个T可以不完整),以”abaaba“举例,我们发现:

S->aba T->ab

aba|aba->abaab|abaab->abaababa|abaababa->abaababaabaab|abaababaabaab

即S|S->ST|ST->STS|STS->STSTS|STSTS。

这是一个斐波那契数列的形式,我们可以对每种字母单独求,因为fib数列到80就会爆1e18,所以时间复杂度不会爆炸,具体地,我们统计每种字母在S中出现次数的前缀和,然后递归计算,把l-1或者r分成很多fib数列的形式,若不满|S|,则直接返回。

Code

#include <bits/stdc++.h>
#define ll long long
using namespace std;
char s[200005];ll len,slen,tlen,sum[30][200005],nex[200005],l,r;
ll solve(ll now,int n)
{
if(now<=len) return sum[n][now];
ll f1=sum[n][slen],f2=sum[n][len],l1=slen,l2=len,tf,tl;
while(l1+l2<now) tf=f2,tl=l2,f2+=f1,l2+=l1,f1=tf,l1=tl;
return f2+solve(now-l2,n);
}
main()
{
scanf("%s%lld%lld",s+1,&l,&r);len=strlen(s+1)/2;
for(int i=2,j=0;i<=len;i++)
{
while(j&&s[i]!=s[j+1]) j=nex[j];
if(s[j+1]==s[i]) nex[i]=++j;
}
slen=len-nex[len];
for(int i=0;i<26;i++) for(int j=1;j<=len;j++)
{
sum[i][j]=sum[i][j-1];
if(s[j]-'a'==i) sum[i][j]++;
}
for(int i=0;i<26;i++) printf("%lld ",solve(r,i)-solve(l-1,i));
}

最新文章

  1. safari cookie设置中文失败
  2. UNITY自带的3D object没有三角形?
  3. PEP 8
  4. PADSPCB权威指南-第三章 预处理(部分)(原创)
  5. JavaScript日期集合(今日,昨日,本周一,周末 ,月初,月末)
  6. hdu4511小明系列故事——女友的考验(ac自动机+最短路)
  7. LLVM
  8. Python字符串、元组、列表、字典互相转换的方法
  9. 2014 Multi-University Training Contest 8
  10. tomcat中的URL参数为中文,servlet接收后显示乱码
  11. flex 错误信息类型及解决方法
  12. OpenGL编程指南第版本学习笔记 --- OpenGL程序实现过程(win32 + OpenGL)
  13. Docker学习——Lepus部署
  14. [Android] Android 使用 FragmentTabHost + Fragment 实现 微信 底部菜单
  15. 树莓派中编译Opencv3.4.1和OpenCVSharp库
  16. 物联网架构成长之路(14)-SpringBoot整合thymeleaf
  17. thinkphp或thinkcmf 《文章编辑,文章添加》 访问另一个表的分类,添加入另一个表时将id值以(,)逗号分隔储存,编辑时以(,)逗号分隔并且相等的id值被选中
  18. 不能安装vmtools解决:一个命令安装
  19. 好用的js模板
  20. ReentrantLock 学习笔记

热门文章

  1. Python Twisted系列教程2:异步编程初探与reactor模式
  2. Lambda语句的嵌套
  3. 微信小程序简单步骤记录
  4. ubuntu12 安装redis和phpRedisAdmin详细流程
  5. Catch That Cow(bfs)
  6. HBase 官方文档中文版
  7. java5 CyclicBarrier同步工具
  8. Eclipse oxygen安装中文包
  9. MAVEN学习总结1
  10. codeforce468DIV2——D. Peculiar apple-tree