http://www.spoj.com/problems/REPEATS/

题意:给一串字符,需要你求这一串字符中有连续重复的字符的重复次数.......

思路:这是和poj3693一种类型的题目......这里是详细解答:http://www.cnblogs.com/ziyi--caolu/p/3193823.html

注意:还需注意的地方,我一直图方便,再求lcp值时,总是从height值的起点到终点,其实应该是起点+1

  1. #include<iostream>
  2. #include<stdio.h>
  3. #include<string.h>
  4. using namespace std;
  5. #define min(x,y) x>y? y:x
  6. #define maxn 51000
  7. int wa[maxn],wv[maxn],sa[maxn],rank[maxn],height[maxn],wb[maxn],wsf[maxn];
  8. int s[maxn],dp[maxn][40];
  9. int cmp(int *r,int a,int b,int k)
  10. {
  11. return r[a]==r[b]&&r[a+k]==r[b+k];
  12. }
  13. void getsa(int *r,int *sa,int n,int m)
  14. {
  15. int i,j,p,*x=wa,*y=wb,*t;
  16. for(i=0;i<m;i++) wsf[i]=0;
  17. for(i=0;i<n;i++) wsf[x[i]=r[i]]++;
  18. for(i=1;i<m;i++) wsf[i]+=wsf[i-1];
  19. for(i=n-1;i>=0;i--) sa[--wsf[x[i]]]=i;
  20. p=1;
  21. j=1;
  22. for(;p<n;j*=2,m=p)
  23. {
  24. for(p=0,i=n-j;i<n;i++) y[p++]=i;
  25. for(i=0;i<n;i++) if(sa[i]>=j) y[p++]=sa[i]-j;
  26. for(i=0;i<n;i++) wv[i]=x[y[i]];
  27. for(i=0;i<m;i++) wsf[i]=0;
  28. for(i=0;i<n;i++) wsf[wv[i]]++;
  29. for(i=1;i<m;i++) wsf[i]+=wsf[i-1];
  30. for(i=n-1;i>=0;i--) sa[--wsf[wv[i]]]=y[i];
  31. t=x;
  32. x=y;
  33. y=t;
  34. x[sa[0]]=0;
  35. for(p=1,i=1;i<n;i++)
  36. x[sa[i]]=cmp(y,sa[i-1],sa[i],j)? p-1:p++;
  37. }
  38. }
  39. void getheight(int *r,int n)
  40. {
  41. int i,j,k=0;
  42. for(i=1;i<=n;i++) rank[sa[i]]=i;
  43. for(i=0;i<n;i++)
  44. {
  45. if(k)
  46. k--;
  47. else
  48. k=0;
  49. j=sa[rank[i]-1];
  50. while(r[i+k]==r[j+k])
  51. k++;
  52. height[rank[i]]=k;
  53. }
  54. }
  55. void rmq_init(int n)
  56. {
  57. for(int i=1;i<=n;i++) dp[i][0]=height[i];
  58. for(int j=1;(1<<j)<=n;j++)
  59. for(int i=1;i+(1<<j)-1<=n;i++)
  60. dp[i][j]=min(dp[i][j-1],dp[i+(1<<(j-1))][j-1]);
  61. }
  62. int rmq(int l,int r)
  63. {
  64. int ll=rank[l];
  65. int rr=rank[r];
  66. if(ll>rr)
  67. {
  68. int tmp=ll;
  69. ll=rr;
  70. rr=tmp;
  71. }
  72. ll++; //注意,ll要++
  73. int k=0;
  74. while((1<<(k+1))<=rr-ll+1) k++;
  75. return min(dp[ll][k],dp[rr-(1<<k)+1][k]);
  76. }
  77. int main()
  78. {
  79. int text;
  80. scanf("%d",&text);
  81. while(text--)
  82. {
  83. int n;
  84. scanf("%d",&n);
  85. for(int i=0;i<n;i++)
  86. {
  87. char ch[10];
  88. scanf("%s",&ch);
  89. s[i]=ch[0]-'a'+1;
  90. }
  91. s[n]=0;
  92. getsa(s,sa,n+1,3);
  93. getheight(s,n);
  94. rmq_init(n);
  95. int ans=0;
  96. for(int i=1;i<=n/2;i++)
  97. {
  98. for(int j=0;j<n-i;j+=i)
  99. {
  100. if(s[j]!=s[i+j])
  101. continue;
  102. int k=rmq(j,i+j);
  103. int d=k/i+1;
  104. int r=i-k%i;
  105. int cnt=0;
  106. for(int m=j-1;m>j-i&&m>=0&&s[m]==s[m+i];m--)
  107. {
  108. cnt++;
  109. if(cnt==r)
  110. {
  111. d++;
  112. }
  113. }
  114. if(ans<d)
  115. ans=d;
  116. }
  117. }
  118. printf("%d\n",ans);
  119. }
  120. return 0;
  121. }

spoj687(后缀数组)的更多相关文章

  1. spoj687 后缀数组重复次数最多的连续重复子串

    REPEATS - Repeats no tags  A string s is called an (k,l)-repeat if s is obtained by concatenating k& ...

  2. spoj687 REPEATS - Repeats (后缀数组+rmq)

    A string s is called an (k,l)-repeat if s is obtained by concatenating k>=1 times some seed strin ...

  3. 【距离GDOI:131天】 后缀数组完毕

    用了近两周的时间,终于把罗神那篇后缀数组应用看完了,题目也写了一遍,T了无数次...详见前几篇博文... 后缀数组很重要的是那个height数组,可以用来做各种奇奇怪怪的东西...常用方法去是去二分, ...

  4. 后缀数组基本问题QAQ

    以下题目均来自罗穗骞的论文... No.1最长公共前缀 最长公共前缀: 题目: 给定一个字符串,询问某两个后缀的最长公共前缀. 分析: 某两个后缀的最长公共前缀就是区间height最小值,转化为RMQ ...

  5. 后缀数组的倍增算法(Prefix Doubling)

    后缀数组的倍增算法(Prefix Doubling) 文本内容除特殊注明外,均在知识共享署名-非商业性使用-相同方式共享 3.0协议下提供,附加条款亦可能应用. 最近在自学习BWT算法(Burrows ...

  6. BZOJ 4199: [Noi2015]品酒大会 [后缀数组 带权并查集]

    4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...

  7. BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1383  Solved: 582[Submit][St ...

  8. POJ3693 Maximum repetition substring [后缀数组 ST表]

    Maximum repetition substring Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9458   Acc ...

  9. POJ1743 Musical Theme [后缀数组]

    Musical Theme Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 27539   Accepted: 9290 De ...

  10. 后缀数组(suffix array)详解

    写在前面 在字符串处理当中,后缀树和后缀数组都是非常有力的工具. 其中后缀树大家了解得比较多,关于后缀数组则很少见于国内的资料. 其实后缀数组是后缀树的一个非常精巧的替代品,它比后缀树容易编程实现, ...

随机推荐

  1. Java Drp项目实战—— 环境搭建

    概要 我们要開始一个关于Java项目的开发,那么我们就须要搭建一个关于Java开发的环境,那么搭建一个Java开发环境,都须要些什么东东,又有些什么注意事项呢. 过程 我先将我搭建Java环境的软件和 ...

  2. 更简单更全的material design状态栏

    从实际使用须要出发,以最简单的方式实现了几种类型的MD状态栏. (重点在fitsSystemWindows的使用) 0,使用前提 Theme.AppCompat.Light.DarkActionBar ...

  3. 广州高清卫星地图 用百度卫星地图server下载 含标签、道路数据叠加 可商用

    广州高清卫星地图的地图展示图片各自是15级别.17级别.19级别的地图.一般来说17级别的地图图片就行用于商用.地图包包括一整张高级别的图片,如要全图浏览请用专业图片处理软件PS等打开. 一般来说互联 ...

  4. Python编程-基础知识-python项目包和文件的管理以及如何引用相对路径的包和模块

    目录 结构: core |____ __init__.py |____ basic |____ __init__.py |____ database           |____ __init__. ...

  5. hdu 2896 AC自动机模版题

    题意:输出出现模式串的id,还是用end记录id就可以了. 本题有个关键点:“以上字符串中字符都是ASCII码可见字符(不包括回车).”  -----也就说AC自动机的Trie树需要128个单词分支. ...

  6. 工具篇:如何使用junit.jar进行测试

    一.网上下载:junit.jar包 下载地址:https://sourceforge.net/projects/junit/?source=typ_redirect 二.导入指定项目中 三.在指定方法 ...

  7. nginx 设置错误的自己定义404页面跳转到500

    5年前写的站, 当时是在apache下写的error page, 换了nginx后, 404页面直接跳到了500 server内部错误. 仅仅须要在配置 try_files 的时候指定一下就能够了 我 ...

  8. keepalived 使用注意事项

    1.启动用service keepalived start/stop 比直接 /sbin/keepalived start/stop要好,貌似解决了master停止了keepalived服务而back ...

  9. hadoop 异常及处理总结-02(小马哥精品)

    一直以来,对hdfs的警告信息不报以理睬,今天突然关注了一下.每当我操作hdfs的时候就会出现这样一个警告: WARN util.NativeCodeLoader: Unable to load na ...

  10. 15-spring学习-集合表达式

    spring认为,数组和List集合是等价的. 要想操作list集合,利用“{内容,内容...}”的形式就可以完成了(类似数组). package com.Spring.ELDemo; import ...