#2842. [GESP七级202503] 等价消除

[GESP七级202503] 等价消除

Description

小 A 有一个仅包含小写英文字母的字符串 SS

对于一个字符串,如果能通过每次删去其中两个相同字符的方式,将这个字符串变为空串,那么称这个字符串是可以被等价消除的。

小 A 想知道 SS 有多少子串是可以被等价消除的。

一个字符串 SS'SS 的子串,当且仅当删去 SS 的某个可以为空的前缀和某个可以为空的后缀之后,可以得到 SS'

Input Format

第一行,一个正整数 S|S|,表示字符串 SS 的长度。

第二行,一个仅包含小写英文字母的字符串 SS

Output Format

一行,一个整数,表示答案。

7
aaaaabb

9

9
babacabab

2

Hint

数据范围

对于 20%20\% 的测试点,保证 SS 中仅包含 aabb 两种字符。

对于另外 20%20\% 的测试点,保证 1S20001 \leq |S| \leq 2000

对于所有测试点,保证 1S2×1051 \leq |S| \leq 2 \times 10^5

Source

2025年3月GESP C++/Python七级