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]\). 思路: 倍增+快排构造后缀数组.代码参考<挑战程序设计竞赛& ...
随机推荐
- 二、Unity Editor模式下,操作选中对象
使用Unity提供的工具类 UnityEditor.Selection public static GameObject activeGameObject public static UnityEng ...
- 关于java调用Dll文件的异常 %1 不是有效的 Win32 应用程序。
这个问题 将java的和编辑器都换成32位
- SQLMAP学习笔记1 access注入
SQLMAP学习笔记1 access注入 Sqlmap是开源的自动化SQL注入工具,由Python写成,具有如下特点: 完全支持MySQL.Oracle.PostgreSQL.Microsoft S ...
- hive的优化
hive.optimize.cp=true:列裁剪hive.optimize.prunner:分区裁剪hive.limit.optimize.enable=true:优化LIMIT n语句hive.l ...
- (二)Hyperledger Fabric 1.1安装部署-Fabric Samples
Hyperledger Fabric Samples是官方推荐的First Network,对于熟悉fabric和测试基础环境很有好处. Fabric Samples源码下载:使用git下载源码,进入 ...
- nodejs 中jead模板改为ejs
var app = express(); // view engine setup app.set('views', path.join(__dirname, 'views')); app.set(' ...
- wifi,Android渗透之arp欺骗
查看自己wifi ip段 查看有哪些用户连接了此wifi,下图标记处为我的测试机(华为) 攻击开始,如果开启了arp防火墙,就会有提示 开启图片捕获
- 如何使用g++编译调用dll的c++代码
本文将有以下4个部分来讲如何使用g++编译调用dll的c++代码. 1.如何调用dll 2.动态链接和静态链接的区别 3.g++的编译参数以及如何编译调用dll的c++代码 4.总结 1.如何调用dl ...
- B2
组员1:吴晓晖(组长) 过去两天完成了哪些任务 代码重构基本完成 展示GitHub当日代码/文档签入记录 接下来的计划 推荐算法 还剩下哪些任务 组员2:陈锦谋 过去两天完成了哪些任务 重新制作图标 ...
- shiro+springmvc 都使用缓存
基于涛哥shiro案例16 的这时候要配置service方法的缓存 在spring-config.xml添加 <context:annotation-config /> <cache ...