【模板题】后缀排序 排行榜
时间限制: 1 s
空间限制: 262144 KB
题目描述
这是一道模板题。
读入一个长度为 $n$ 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置。位置编号为 $1$ 到 $n$。
除此之外为了进一步证明你确实有给后缀排序的超能力,请另外输出 $n-1$ 个整数分别表示排序后相邻后缀的最长公共前缀的长度。
输入格式
从标准输入读入数据。
一行一个长度为 $n$ 的仅包含小写英文字母的字符串。
输出格式
输出到标准输出。
第一行 $n$ 个整数,第 $i$ 个整数表示排名为 $i$ 的后缀的第一个字符在原串中的位置。
第二行 $n-1$ 个整数,第 $i$ 个整数表示排名为 $i$ 和排名为 $i+1$ 的后缀的最长公共前缀的长度。
样例输入
样例输出
样例解释
排序后结果为:
- a
- aba
- ababa
- ba
- baba
数据范围
$1 \le n \le 10^{5}$
题目来源
关于接口中的数组初值说明(最后更新:2023年2月6日)
若题目要求实现函数接口,且该函数中存在仅用于输出的数组(如 void solve(int n, const int *in, int *out)
中的 out
),那么除非另外说明,否则该数组在程序启动时的初值为 0
。
关于标准输出的说明(最后更新:2018年10月23日)
标准输出将被重定向到内存中,所以你的内存使用量也包括了你的标准输出的大小(向上取整到 4KB 的倍数)。
如果你的程序要进行大量输出,请考虑这一点。
关于提交的说明
你提交的代码将会被公开,所有人都可见。如果这不是你所期望的,或者如果想要删除已提交的代码,请联系管理员。
Judge Duck Online | 评测鸭在线
Server Time: 2024-11-22 07:39:29 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠