#ATagc048a. [AGC048A] atcoder < S

[AGC048A] atcoder < S

题目描述

给定一个由小写英文字母组成的字符串 SS。すぬけ君可以进行如下操作:交换 SS相邻的两个字符。例如,若 S=S=agc,则一次操作可以将 SS 变为 gac(交换 ag),或变为 acg(交换 gc)。

すぬけ君可以重复进行该操作 00 次或多次,目标是使得 SS 在字典序上满足 atcoder <S< S

字典序 x<yx < y 的定义如下:对于字符串 x,yx, y,若满足以下任一条件,则称 xx 在字典序上小于 yy

  • 存在某个整数 ii1imin(x,y)1 \leq i \leq \min(|x|, |y|)),使得 xxyy 的前 i1i-1 个字符相同,且 xx 的第 ii 个字符在字母表中严格小于 yy 的第 ii 个字符。
  • x<y|x| < |y|,且 yy 的前 x|x| 个字符与 xx 完全相同。

请判断目标是否可以达成。如果可以,输出所需操作次数的最小值;如果无法达成,输出 1-1

对于每个输入文件,需要解答 TT 个测试用例。

输入格式

输入从标准输入读入,格式如下:

TT

接下来有 TT 个测试用例。每个测试用例格式如下:

SS

输出格式

对于每个测试用例,如果目标无法达成,输出 1-1;如果可以达成,输出所需操作次数的最小值。每个测试用例输出一行。

样例 1

输入

3
atcodeer
codeforces
aaa

输出

1
0
-1

说明/提示

限制条件

  • 1T1001 \leq T \leq 100
  • 1S10001 \leq |S| \leq 1000
  • SS 由小写英文字母组成。

样例解释 1

  • 11 个测试用例:例如,将末尾的 22 个字符交换后,S=S=atcodere >> atcoder
  • 22 个测试用例:无需任何操作,S=S=codeforces >> atcoder
  • 33 个测试用例:无论如何操作,都无法使 S>S > atcoder

由 ChatGPT 4.1 翻译