题目链接:http://uoj.ac/problem/35

这是一道模板题。

读入一个长度为 n 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置。位置编号为 1 到 n。

除此之外为了进一步证明你确实有给后缀排序的超能力,请另外输出 n−1 个整数分别表示排序后相邻后缀的最长公共前缀的长度。

输入格式

一行一个长度为 n 的仅包含小写英文字母的字符串。

输出格式

第一行 n 个整数,第 i 个整数表示排名为 i 的后缀的第一个字符在原串中的位置。

第二行 n−1个整数,第 i 个整数表示排名为 i 和排名为 i+1 的后缀的最长公共前缀的长度。

样例一

input

ababa

output

5 3 1 4 2
1 3 0 2

explanation

排序后结果为:

  1. a
  2. aba
  3. ababa
  4. ba
  5. baba

限制与约定

1≤n≤10^5

时间限制:1s

空间限制:256MB

感想:

对uoj非常的资瓷啊,后缀数组裸题,不懂的自行百度

献上一个大爷的博客链接:http://blog.csdn.net/shiqi_614/article/details/7982915

代码

#include <cstdio>
#include <cstring>
using namespace std;
int i,j,k,n,m,x,y,t,a[],b[],b1[],d[],rk[],p[],h[],s1[];
int height[],ans1[];
char s[];
struct data{int x,y;}c[],e[];
void get_sa(){
for (i=;i<=n;i++)b[s[i]-'a']=;
for (i=;i<;i++)b[i]+=b[i-];
for (i=;i<=n;i++)a[i]=b[s[i]-'a'];
for (k=;k<=n;k*=){
for (i=;i<=n;i++)c[i].x=a[i],c[i].y=a[i+k];
memset(b,,sizeof b);
for (i=;i<=n;i++)b[c[i].y]++;
for (i=;i<=n;i++)b[i]+=b[i-];
for (i=;i<=n;i++)d[b[c[i].y]]=i,b[c[i].y]--;
for (i=;i<=n;i++)e[i]=c[d[i]];
for (i=;i<=n;i++)c[i]=e[i];
for (i=;i<=n;i++)p[i]=d[i];
memset(b,,sizeof b);
for (i=;i<=n;i++)b[c[i].x]++;
for (i=;i<=n;i++)b[i]+=b[i-];
for (i=n;i>=;i--)d[b[c[i].x]]=i,b[c[i].x]--;
for (i=;i<=n;i++)e[i]=c[d[i]],rk[i]=d[i];
for (i=;i<=n;i++)c[i]=e[i];
s1[]=;
for (i=;i<=n;i++)if (c[i].x!=c[i-].x||c[i].y!=c[i-].y)s1[i]=s1[i-]+;else s1[i]=s1[i-];
for (i=;i<=n;i++)a[p[rk[i]]]=s1[i];
}
for (i=;i<=n;i++)rk[a[i]]=i;
for (i=;i<=n;i++)printf("%d ",rk[i]);printf("\n");
}
void get_h(){
int k=;
for (int i=;i<=n;i++){
if (a[i]==) h[i]=k=;
else{
j=rk[a[i]-];
if (k>) k--;
while (i+k<=n&&j+k<=n&&s[i+k]==s[j+k]) k++;
h[i]=k;
}
height[a[i]]=h[i];
}
for (int i=; i<=n; i++) printf("%d ",height[i]);
}
int main(){
gets(s);
n=strlen(s);
for (i=n;i>=;i--)s[i]=s[i-];
get_sa();
get_h();
return ;
}

uoj35 后缀排序的更多相关文章

  1. UOJ35 后缀数组(模板)

    #35. 后缀排序 这是一道模板题. 读入一个长度为 nn 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置.位置编号为 1 ...

  2. codevs1500 后缀排序

    题目描述 Description 天凯是MIT的新生.Prof. HandsomeG给了他一个长度为n的由小写字母构成的字符串,要求他把该字符串的n个后缀(suffix)从小到大排序. 何谓后缀?假设 ...

  3. UOJ#35 后缀排序

    这是一道模板题. 读入一个长度为 n 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置.位置编号为 1 到 n. 除此之外为 ...

  4. P3809 【模板】后缀排序

    P3809 [模板]后缀排序 从这学的 后缀数组sa[i]就表示排名为i的后缀的起始位置 x[i]是第i个元素的第一关键字 y[i]表示第二关键字排名为i的数,在第一关键字中的位置 #include& ...

  5. LG3809 【模板】后缀排序

    题意 题目背景 这是一道模板题. 题目描述 读入一个长度为 $ n $ 的由大小写英文字母或数字组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的 ...

  6. 2018.11.24 loj#111. 后缀排序(后缀数组)

    传送门 后缀排序模板题. 终于会后缀数组了(然而只会倍增并不会DC3DC3DC3). 在这里列举几个数组的意思: sai:sa_i:sai​:当前排名第iii的后缀的起始下标. rkirk_irki​ ...

  7. codevs 1500 后缀排序

    codevs 1500 后缀排序 http://codevs.cn/problem/1500/  时间限制: 1 s  空间限制: 128000 KB   题目描述 Description 天凯是MI ...

  8. 洛谷:P3809 【模板】后缀排序(后缀数组模板)

    P3809 [模板]后缀排序 题目链接:https://www.luogu.org/problemnew/show/P3809 题目背景 这是一道模板题. 题目描述 读入一个长度为 nn 的由大小写英 ...

  9. [洛谷P3809]【模板】后缀排序

    [洛谷P3809][模板]后缀排序 题目大意: 对于给定的长度为\(n(n\le10^6)\)的字符串求后缀数组\(sa[i]\). 思路: 倍增+快排构造后缀数组.代码参考<挑战程序设计竞赛& ...

随机推荐

  1. 如何配置pycaffe

    首先,使用cmake配置.生成caffe的vs2015工程时,设定生成python接口,即BUILD项->BUILD_python.BUILD_python_layer,注意使用CMake生成V ...

  2. 配置独立于系统的PYTHON环境

    配置独立于系统的PYTHON环境 python 当前用户包 一种解决方案是在利用本机的python环境的基础上,将python的包安装在当前user的.local文件夹下 一共有两种方式来实现pip的 ...

  3. java基础---JDK、JRE、JVM的区别和联系

    当我们学习java语言时,首先需要安装到我们电脑上的就是jdk.jdk是java语言的开发环境,只有安装了jdk,我们才能使用java语言开发程序. JDK=JRE+开发工具包 JRE=JVM+核心类 ...

  4. CocoStuff—基于Deeplab训练数据的标定工具【一、翻译】(未完)

    一.CocoStuff简介 CocoStuff是一款为deeplab设计的,运行在Matlab中的语义标定工具,其标定结果和结合Deeplab训练出的结果均为mat文件格式,该项目源码已在github ...

  5. Dede织梦验证码不显示,织梦后台登陆验证码不显示解决方法

    关于"织梦验证码不显示"的解决方法 "织梦验证码无法显示出来"的问题分析? 1.之前显示正常,但是换了服务器后就不能够正常显示:(这种通常是网站程序经过迁移后所 ...

  6. [2017 ACL] 对话系统

    Long Papers [Domain adaptation ] 1. Adversarial Adaptation of Synthetic or Stale Data ( Cited by 14 ...

  7. python json模块使用详情

    python其他知识目录 #json.数据交换用到json文件.json是特殊的字符串.访问网站,返回的就是json 1.json简介: 定义:JSON(JavaScript Object Notat ...

  8. Spring Bean注册解析(二)

           在上文Spring Bean注册解析(一)中,我们讲解了Spring在注册Bean之前进行了哪些前期工作,以及Spring是如何存储注册的Bean的,并且详细介绍了Spring是如何解析 ...

  9. 团队C++作业1

    我的分工 在本次作业中,我负责的是建筑类的完成还有调试运行. 建筑类的完成: 首先我认为建筑类的完成中,建筑类中应该有三个成员,水晶,防御塔,泉水. 水晶在这个里头是要被保护的对象,它的功能有回血还有 ...

  10. windows redis 后台运行

    1. 进入 DOS窗口2. 在进入Redis的安装目录3. 输入:redis-server --service-install redis.windows.conf --loglevel verbos ...