spoj687(后缀数组)
http://www.spoj.com/problems/REPEATS/
题意:给一串字符,需要你求这一串字符中有连续重复的字符的重复次数.......
思路:这是和poj3693一种类型的题目......这里是详细解答:http://www.cnblogs.com/ziyi--caolu/p/3193823.html
注意:还需注意的地方,我一直图方便,再求lcp值时,总是从height值的起点到终点,其实应该是起点+1
- #include<iostream>
- #include<stdio.h>
- #include<string.h>
- using namespace std;
- #define min(x,y) x>y? y:x
- #define maxn 51000
- int wa[maxn],wv[maxn],sa[maxn],rank[maxn],height[maxn],wb[maxn],wsf[maxn];
- int s[maxn],dp[maxn][40];
- int cmp(int *r,int a,int b,int k)
- {
- return r[a]==r[b]&&r[a+k]==r[b+k];
- }
- void getsa(int *r,int *sa,int n,int m)
- {
- int i,j,p,*x=wa,*y=wb,*t;
- for(i=0;i<m;i++) wsf[i]=0;
- for(i=0;i<n;i++) wsf[x[i]=r[i]]++;
- for(i=1;i<m;i++) wsf[i]+=wsf[i-1];
- for(i=n-1;i>=0;i--) sa[--wsf[x[i]]]=i;
- p=1;
- j=1;
- for(;p<n;j*=2,m=p)
- {
- for(p=0,i=n-j;i<n;i++) y[p++]=i;
- for(i=0;i<n;i++) if(sa[i]>=j) y[p++]=sa[i]-j;
- for(i=0;i<n;i++) wv[i]=x[y[i]];
- for(i=0;i<m;i++) wsf[i]=0;
- for(i=0;i<n;i++) wsf[wv[i]]++;
- for(i=1;i<m;i++) wsf[i]+=wsf[i-1];
- for(i=n-1;i>=0;i--) sa[--wsf[wv[i]]]=y[i];
- t=x;
- x=y;
- y=t;
- x[sa[0]]=0;
- for(p=1,i=1;i<n;i++)
- x[sa[i]]=cmp(y,sa[i-1],sa[i],j)? p-1:p++;
- }
- }
- void getheight(int *r,int n)
- {
- int i,j,k=0;
- for(i=1;i<=n;i++) rank[sa[i]]=i;
- for(i=0;i<n;i++)
- {
- if(k)
- k--;
- else
- k=0;
- j=sa[rank[i]-1];
- while(r[i+k]==r[j+k])
- k++;
- height[rank[i]]=k;
- }
- }
- void rmq_init(int n)
- {
- for(int i=1;i<=n;i++) dp[i][0]=height[i];
- for(int j=1;(1<<j)<=n;j++)
- for(int i=1;i+(1<<j)-1<=n;i++)
- dp[i][j]=min(dp[i][j-1],dp[i+(1<<(j-1))][j-1]);
- }
- int rmq(int l,int r)
- {
- int ll=rank[l];
- int rr=rank[r];
- if(ll>rr)
- {
- int tmp=ll;
- ll=rr;
- rr=tmp;
- }
- ll++; //注意,ll要++
- int k=0;
- while((1<<(k+1))<=rr-ll+1) k++;
- return min(dp[ll][k],dp[rr-(1<<k)+1][k]);
- }
- int main()
- {
- int text;
- scanf("%d",&text);
- while(text--)
- {
- int n;
- scanf("%d",&n);
- for(int i=0;i<n;i++)
- {
- char ch[10];
- scanf("%s",&ch);
- s[i]=ch[0]-'a'+1;
- }
- s[n]=0;
- getsa(s,sa,n+1,3);
- getheight(s,n);
- rmq_init(n);
- int ans=0;
- for(int i=1;i<=n/2;i++)
- {
- for(int j=0;j<n-i;j+=i)
- {
- if(s[j]!=s[i+j])
- continue;
- int k=rmq(j,i+j);
- int d=k/i+1;
- int r=i-k%i;
- int cnt=0;
- for(int m=j-1;m>j-i&&m>=0&&s[m]==s[m+i];m--)
- {
- cnt++;
- if(cnt==r)
- {
- d++;
- }
- }
- if(ans<d)
- ans=d;
- }
- }
- printf("%d\n",ans);
- }
- return 0;
- }
spoj687(后缀数组)的更多相关文章
- spoj687 后缀数组重复次数最多的连续重复子串
REPEATS - Repeats no tags A string s is called an (k,l)-repeat if s is obtained by concatenating k& ...
- 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 ...
- 【距离GDOI:131天】 后缀数组完毕
用了近两周的时间,终于把罗神那篇后缀数组应用看完了,题目也写了一遍,T了无数次...详见前几篇博文... 后缀数组很重要的是那个height数组,可以用来做各种奇奇怪怪的东西...常用方法去是去二分, ...
- 后缀数组基本问题QAQ
以下题目均来自罗穗骞的论文... No.1最长公共前缀 最长公共前缀: 题目: 给定一个字符串,询问某两个后缀的最长公共前缀. 分析: 某两个后缀的最长公共前缀就是区间height最小值,转化为RMQ ...
- 后缀数组的倍增算法(Prefix Doubling)
后缀数组的倍增算法(Prefix Doubling) 文本内容除特殊注明外,均在知识共享署名-非商业性使用-相同方式共享 3.0协议下提供,附加条款亦可能应用. 最近在自学习BWT算法(Burrows ...
- BZOJ 4199: [Noi2015]品酒大会 [后缀数组 带权并查集]
4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...
- BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1383 Solved: 582[Submit][St ...
- POJ3693 Maximum repetition substring [后缀数组 ST表]
Maximum repetition substring Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9458 Acc ...
- POJ1743 Musical Theme [后缀数组]
Musical Theme Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 27539 Accepted: 9290 De ...
- 后缀数组(suffix array)详解
写在前面 在字符串处理当中,后缀树和后缀数组都是非常有力的工具. 其中后缀树大家了解得比较多,关于后缀数组则很少见于国内的资料. 其实后缀数组是后缀树的一个非常精巧的替代品,它比后缀树容易编程实现, ...
随机推荐
- Java Drp项目实战—— 环境搭建
概要 我们要開始一个关于Java项目的开发,那么我们就须要搭建一个关于Java开发的环境,那么搭建一个Java开发环境,都须要些什么东东,又有些什么注意事项呢. 过程 我先将我搭建Java环境的软件和 ...
- 更简单更全的material design状态栏
从实际使用须要出发,以最简单的方式实现了几种类型的MD状态栏. (重点在fitsSystemWindows的使用) 0,使用前提 Theme.AppCompat.Light.DarkActionBar ...
- 广州高清卫星地图 用百度卫星地图server下载 含标签、道路数据叠加 可商用
广州高清卫星地图的地图展示图片各自是15级别.17级别.19级别的地图.一般来说17级别的地图图片就行用于商用.地图包包括一整张高级别的图片,如要全图浏览请用专业图片处理软件PS等打开. 一般来说互联 ...
- Python编程-基础知识-python项目包和文件的管理以及如何引用相对路径的包和模块
目录 结构: core |____ __init__.py |____ basic |____ __init__.py |____ database |____ __init__. ...
- hdu 2896 AC自动机模版题
题意:输出出现模式串的id,还是用end记录id就可以了. 本题有个关键点:“以上字符串中字符都是ASCII码可见字符(不包括回车).” -----也就说AC自动机的Trie树需要128个单词分支. ...
- 工具篇:如何使用junit.jar进行测试
一.网上下载:junit.jar包 下载地址:https://sourceforge.net/projects/junit/?source=typ_redirect 二.导入指定项目中 三.在指定方法 ...
- nginx 设置错误的自己定义404页面跳转到500
5年前写的站, 当时是在apache下写的error page, 换了nginx后, 404页面直接跳到了500 server内部错误. 仅仅须要在配置 try_files 的时候指定一下就能够了 我 ...
- keepalived 使用注意事项
1.启动用service keepalived start/stop 比直接 /sbin/keepalived start/stop要好,貌似解决了master停止了keepalived服务而back ...
- hadoop 异常及处理总结-02(小马哥精品)
一直以来,对hdfs的警告信息不报以理睬,今天突然关注了一下.每当我操作hdfs的时候就会出现这样一个警告: WARN util.NativeCodeLoader: Unable to load na ...
- 15-spring学习-集合表达式
spring认为,数组和List集合是等价的. 要想操作list集合,利用“{内容,内容...}”的形式就可以完成了(类似数组). package com.Spring.ELDemo; import ...