【模板题】后缀排序 排行榜


时间限制: 1 s
空间限制: 256 MB

题目描述

这是一道模板题。

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

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

输入格式

从标准输入读入数据。

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

输出格式

输出到标准输出。

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

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

样例输入

样例输出

样例解释

排序后结果为:

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

数据范围

$1 \le n \le 10^{5}$

题目来源

UOJ #35. 后缀排序


关于标准输出的说明(最后更新:2018年10月23日)

标准输出将被重定向到内存中,所以你的内存使用量也包括了你的标准输出的大小(向上取整到 4KB 的倍数)。

如果你的程序要进行大量输出,请考虑这一点。




Judge Duck Online | 评测鸭在线
Server Time: 2019-06-27 02:46:50 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用