uoj35 后缀排序
题目链接: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
排序后结果为:
- a
- aba
- ababa
- ba
- 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 后缀排序的更多相关文章
- UOJ35 后缀数组(模板)
#35. 后缀排序 这是一道模板题. 读入一个长度为 nn 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置.位置编号为 1 ...
- codevs1500 后缀排序
题目描述 Description 天凯是MIT的新生.Prof. HandsomeG给了他一个长度为n的由小写字母构成的字符串,要求他把该字符串的n个后缀(suffix)从小到大排序. 何谓后缀?假设 ...
- UOJ#35 后缀排序
这是一道模板题. 读入一个长度为 n 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置.位置编号为 1 到 n. 除此之外为 ...
- P3809 【模板】后缀排序
P3809 [模板]后缀排序 从这学的 后缀数组sa[i]就表示排名为i的后缀的起始位置 x[i]是第i个元素的第一关键字 y[i]表示第二关键字排名为i的数,在第一关键字中的位置 #include& ...
- LG3809 【模板】后缀排序
题意 题目背景 这是一道模板题. 题目描述 读入一个长度为 $ n $ 的由大小写英文字母或数字组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的 ...
- 2018.11.24 loj#111. 后缀排序(后缀数组)
传送门 后缀排序模板题. 终于会后缀数组了(然而只会倍增并不会DC3DC3DC3). 在这里列举几个数组的意思: sai:sa_i:sai:当前排名第iii的后缀的起始下标. rkirk_irki ...
- codevs 1500 后缀排序
codevs 1500 后缀排序 http://codevs.cn/problem/1500/ 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description 天凯是MI ...
- 洛谷:P3809 【模板】后缀排序(后缀数组模板)
P3809 [模板]后缀排序 题目链接:https://www.luogu.org/problemnew/show/P3809 题目背景 这是一道模板题. 题目描述 读入一个长度为 nn 的由大小写英 ...
- [洛谷P3809]【模板】后缀排序
[洛谷P3809][模板]后缀排序 题目大意: 对于给定的长度为\(n(n\le10^6)\)的字符串求后缀数组\(sa[i]\). 思路: 倍增+快排构造后缀数组.代码参考<挑战程序设计竞赛& ...
随机推荐
- MYSQL 数据库结构优化
数据库结构优化 优化数据大小 使表占用尽量少的磁盘空间.减少磁盘I/O次数及读取数据量是提升性能的基础原则.表越小,数据读写处理时则需要更少的内存,同时,小表的索引占用也相对小,索引处理也更加快速. ...
- v-if、v-show 指令
HTML部分: <div id="app"> <button type="button" @click="flag=!flag&qu ...
- github在版本库中删除某个文件的所有历史记录
github的目的就是版本控制,记录每一个版本的变动.然而有的时候我们往往希望从版本库中彻底删除某个文件,不再显示在历史记录中.例如不小心上传了一堆错误的文件,或者不小心上传了帐号.密码,那么这个时候 ...
- ReLU——Deep Sparse Rectifier Neural Networks
1. 摘要 ReLU 相比 Tanh 能产生相同或者更好的性能,而且能产生真零的稀疏表示,非常适合自然就稀疏的数据. 采用 ReLU 后,在大量的有标签数据下,有没有无监督预训练模型取得的最好效果是一 ...
- 记一次centos6升级salt-minion启动失败的问题
记一次centos6升级salt-minion启动失败的问题 作者:耀耀 blog:https://www.liuyao.me 一.起因 升级Salt-minion后 使用/etc/init.d/sa ...
- D.王者荣耀交流协会——PSP Daily(测评人:贾男男)
D.王者荣耀交流协会——PSP Daily(测评人:贾男男) 一.基于NABCD评论作品,及改进建议 每个小组评论其他小组beta发布的作品.1.根据(不限于)NABCD评论作品的选题;2.评论作品对 ...
- php之 常用的 流程管理
1.流程管理的用法是什么样的? 2.怎么发起想要的流程? 3.审批的人要是怎么审批通过? 4.流程审核是不是要挨个走过? 一.要有数据库的内容的 肯定会有表的,首先就是用户表了,然后就是流程表,用户编 ...
- Leetcode题库——13.罗马数字转整数
@author: ZZQ @software: PyCharm @file: Luoma2Int.py @time: 2018/9/16 17:06 要求: 罗马数字转数字 字符 数值 I 1 V 5 ...
- 【动态规划】POJ-2229
一.题目 Description Farmer John commanded his cows to search for different sets of numbers that sum to ...
- 关于Eclipse上使用可视化设计界面(Java EE 使用可视化界面设计)
Eclipse下可视化界面实现——WindowBulider安装 第一步: WindowBuilder官方下载安装说明地址:http://www.eclipse.org/windowbuilder/d ...