luogu#P3501. [POI 2010] ANT-Antisymmetry

    ID: 2574 远端评测题 1000ms 125MiB 尝试: 0 已通过: 0 难度: 7 上传者: 标签>2010二分POI(波兰)哈希 hashingManacher 算法

[POI 2010] ANT-Antisymmetry

题目描述

译自 POI 2010 Stage 2. Day 0「Antisymmetry

对于一个 0/10/1 字符串,如果将这个字符串 0011 取反后,再将整个串反过来和原串一样,就称作「反对称」字符串。比如 0000111100001111010101010101 就是反对称的,而 10011001 就不是。
现在给出一个长度为 nn0/10/1 字符串,求它有多少个子串是反对称的,注意这里相同的子串出现在不同的位置会被重复计算。

输入格式

第一行一个正整数 nn
第二行一个长度为 nn0/10/1 字符串。

输出格式

一行一个整数,表示原串的反对称子串个数。

8
11001011
7

提示

样例的 77 个反对称子串分别是:0101(出现两次),1010(出现两次),0101010111001100001011001011

对于 100%100\% 的数据, 1n500 0001\le n\le 500\ 000

翻译来自于 LibreOJ