4688 - 等价消除

题目描述

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

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

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

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

输入

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

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

输出

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

样例

输入

7
aaaaabb

输出

9

输入

9
babacabab

输出

2
说明

数据范围

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

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

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

来源

2025年GESP 3月认证C++七级真题

标签
题目参数
时间限制 1 秒
内存限制 512 MB
提交次数 19
通过人数 14
金币数量 1 枚
难度 基础


上一题 下一题