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


时间限制: 1 s
空间限制: 262144 KB

题目描述

这是一道模板题。

读入一个长度为 $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. 后缀排序


关于接口中的数组初值说明(最后更新: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
个人娱乐项目,仅供学习交流使用 | 捐赠