#aBC223B. [ABC223B] String Shifting

[ABC223B] String Shifting

AT_abc223_b [ABC223B] String Shifting

题目描述

对于一个非空字符串,将首字母移动到末尾的操作称为左移,将末尾字母移动到首位的操作称为右移

例如,对 abcde 进行 11 次左移后得到 bcdea,进行 22 次右移后得到 deabc

给定一个仅由小写英文字母组成的非空字符串 SS。请你求出对 SS 进行任意次数(可以为 00 次)的左移或右移操作后能得到的所有字符串中,按字典序最小和最大的字符串。

什么是字典序?字典序简单来说就是“单词在字典中出现的顺序”。更严格地说,判断由小写英文字母组成的两个不同字符串 S, TS,\ T 的大小关系的算法如下:

SS 的第 ii 个字符为 SiS_i。若 SS 在字典序上小于 TT,记作 S<TS < T,大于则记作 S>TS > T

  1. S, TS,\ T 中较短的字符串长度为 LL。依次比较 i=1,2,,Li=1,2,\dots,LSiS_iTiT_i 是否相等。
  2. 如果存在 SiTiS_i \neq T_i,则取最小的此类 iijj,比较 SjS_jTjT_j。若 SjS_j 的字母序小于 TjT_j,则 S<TS < T,否则 S>TS > T,算法结束。
  3. 如果所有 Si=TiS_i = T_i,则比较 SSTT 的长度,短的为小,长的为大,算法结束。

输入格式

输入为一行,包含一个字符串 SS

输出格式

输出 22 行。第一行为对 SS 进行任意次数左移或右移操作后能得到的所有字符串中字典序最小的字符串 SminS_{\min},第二行为字典序最大的字符串 SmaxS_{\max}

输入输出样例 #1

输入 #1

aaba

输出 #1

aaab
baaa

输入输出样例 #2

输入 #2

z

输出 #2

z
z

输入输出样例 #3

输入 #3

abracadabra

输出 #3

aabracadabr
racadabraab

说明/提示

限制条件

  • SS 仅由小写英文字母组成。
  • SS 的长度为 1110001000

样例解释 1

通过操作,可以得到 aaabaabaabaabaaa44 种字符串。其中字典序最小和最大分别为 aaabbaaa

样例解释 2

无论如何操作,得到的字符串都只有 z

由 ChatGPT 4.1 翻译