#ATagc019b. [AGC019B] Reverse and Compare

[AGC019B] Reverse and Compare

题目描述

有一个由小写英文字母组成的字符串 A=A1A2...AnA = A_1A_2...A_n

你可以选择任意满足 1ijn1 \leq i \leq j \leq n 的两个下标 i,ji, j,将 AA 的某个子串 AiAi+1...AjA_iA_{i+1}...A_j 进行反转。

这个操作最多只能执行一次。

通过这个操作可以得到多少种不同的字符串?

输入格式

输入将按照以下格式从标准输入读入。

AA

输出格式

输出通过至多一次对 AA 的任意子串反转操作能得到的不同字符串的个数。

样例 1

输入

aatt

输出

5

样例 2

输入

xxxxxxxxxx

输出

1

样例 3

输入

abracadabra

输出

44

说明/提示

限制条件

  • 1A200, ⁣0001 \leq |A| \leq 200,\!000
  • AA 仅由小写英文字母组成。

样例解释 1

可以得到的字符串有 aatt(什么都不做)、atat(反转 A[2..3]A[2..3])、atta(反转 A[2..4]A[2..4])、ttaa(反转 A[1..4]A[1..4])、taat(反转 A[1..3]A[1..3])。

样例解释 2

无论反转哪个部分子串,最终结果都是 xxxxxxxxxx

由 ChatGPT 5 翻译