题目描述

如果把一个字符串从头到尾翻转后和原字符串相等,我们称之为回文串,比如“aabaa”、“())(”、“2017102”。

如果一个字符串存在两个出现过的字母出现的次数相等,我们称之为好

的字符串。

现在给一个由小写字母组成的字符串,问在这个字符串的所有连续的串

中,好的回文串有多少个。(两个相同的回文串出现在不同位置算多次)。

输入输出格式

输入格式:

一行一个小写字母组成的字符串。

输出格式:

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

输入输出样例

输入样例#1:

abcbaabcba
输出样例#1:

6
【样例解释】
abcba s[1..5] a,b 出现次数相等
baab s[4..7] a,b 出现次数相等
cbaabc s[3..8] a,b 出现次数相等
bcbaabcb s[2..9] a,c 出现次数相等
abcbaabcba s[1..10] a,b 出现次数相等
abcba s[6..10] a,b 出现次数相等

说明

len 表示字符串长度。

对于30% 的数据, len <=10^2。

对于60% 的数据, len <= 10^3。

对于100% 的数据,1 <= len <= 10^4。

 /*
我们发现回文串是可以二分的
比如:bbbabcbaabcba 我们以第1个c为中心,发现回文半径是3,大于3一定不是回文串。当回文串长度为偶数的时候,我们需要特殊处理一下。
现在有一个结论:本质不同的回文串个数只有O(N)个
本质不同:字符串本身是不同的。
每一次处理完回文串,我们要把他的hash值记录下来。
*/ #include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
using namespace std; typedef unsigned long long ULL;
typedef long long LL; char s[];
ULL h[],rh[],pw[];
int L; ULL hs(int l,int r)
{
return h[r]-h[l-]*pw[r-l+];
}
ULL rhs(int l,int r)
{
return rh[l]-rh[r+]*pw[r-l+];
}
struct N
{
int a[];
bool ok(){
int b[];
for(int i=;i<;i++) b[i]=a[i];
sort(b,b+);
for(int i=;i<;i++)
{
if(b[i]>&& b[i] == b[i+]) return true;
}
return false;
}
void clear()
{
memset(a,,sizeof a);
}
};
LL ans=;
map<ULL,LL> num;
map<ULL,N> A;
void solve_odd() //奇数
{
for(int i=;i<=L;i++)
{
int l=,r=min(i,L-i+)+;
while(r-l>)
{
int mid=(l+r)/;
if(hs(i-mid+,i+mid-)==rhs(i-mid+,i+mid-)) l=mid;
else r=mid;
}
int p=l;
int tmp=p;
while(tmp>=&&num.find(hs(i-tmp+,i+tmp-))==num.end()) tmp--;
LL sum=;
N st;
st.clear();
if(tmp>=)
{
sum=num[hs(i-tmp+,i+tmp-)];
st=A[hs(i-tmp+,i+tmp-)];
}
while(tmp<p)
{
st.a[s[i+tmp]-'a']+=(tmp==?:);
if(st.ok()) sum++;
num[hs(i-tmp,i+tmp)]=sum;
A[hs(i-tmp,i+tmp)]=st;
tmp++;
}
ans+=sum;
}
}
void solve_even() //偶数
{
A.clear();
num.clear();
for(int i=;i<L;i++)
{
int l=,r=min(i,L-i)+;
while(r-l>)
{
int mid=(l+r)/;
if(hs(i-mid+,i+mid)== rhs(i-mid+,i+mid)) l=mid;
else r=mid;
}
int p=l;
int tmp=p;
while(tmp>=&&num.find(hs(i-tmp+,i+tmp))==num.end()) tmp--;
LL sum = ;
N st;
st.clear();
if(tmp>=)
{
sum=num[hs(i-tmp+,i+tmp)];
st=A[hs(i-tmp+,i+tmp)];
}
while(tmp<p)
{
st.a[s[i+tmp+]-'a']+=;
if(st.ok()) sum++;
num[hs(i-tmp,i+tmp+)]=sum;
A[hs(i-tmp,i+tmp+)]=st;
tmp++;
}
ans+=sum;
}
} int main()
{
scanf("%s",s+);
L=strlen(s+);
s[]='#';
pw[]=;
for(int i=;i<=L;i++) pw[i]=pw[i-]*; ///hash值
for(int i=;i<=L;i++) h[i]=h[i-]*+s[i];
for(int i=L;i>=;i--) rh[i]=rh[i+]*+s[i];
solve_odd();
solve_even();
printf("%lld\n",ans);
fclose(stdout);
return ;
}

2017.10.6 国庆清北 D6T3 字符串的更多相关文章

  1. 2017.10.1 国庆清北 D1T1 zhx的字符串题

    题目背景 2017国庆清北D1T1 题目描述 你是能看到第一题的 friends 呢. ——hja 何大爷对字符串十分有研究,于是天天出字符串题虐杀 zhx.何大爷今天为 字符串定义了新的权值计算方法 ...

  2. 2017.10.3 国庆清北 D3T1 括号序列

    题目描述 LYK有一个括号序列,但这个序列不一定合法. 一个合法的括号序列如下: ()是合法的括号序列. 若A是合法的括号序列,则(A)是合法的括号序列. 若A和B分别是合法的括号序列,则AB是合法的 ...

  3. 2017.10.4 国庆清北 D4T2 正方形

    题目描述 在一个10000*10000的二维平面上,有n颗糖果. LYK喜欢吃糖果!并且它给自己立了规定,一定要吃其中的至少C颗糖果! 事与愿违,LYK只被允许圈出一个正方形,它只能吃在正方形里面的糖 ...

  4. 2017.10.6 国庆清北 D6T2 同余方程组

    题目描述 求关于x 的同余方程组 x%a1 = b1 x%a2 = b2 x%a3 = b3 x%a4 = b4 的大于等于0 的最小整数解. 输入输出格式 输入格式: 一行8 个整数,表示a1; b ...

  5. 2017.10.6 国庆清北 D6T1 排序

    题目描述 小Z 有一个数字序列a1; a2; .... ; an,长度为n,小Z 只有一个操作:选 定p(1<p<n),然后把ap 从序列中拿出,然后再插⼊到序列中任意位置. 比如a 序列 ...

  6. 2017.10.3 国庆清北 D3T3 解迷游戏

    题目描述 LYK进了一家古董店,它很想买其中的一幅画.但它带的钱不够买这幅画. 幸运的是,老板正在研究一个问题,他表示如果LYK能帮他解出这个问题的话,就把这幅画送给它. 老板有一个n*m的矩阵,他想 ...

  7. 2017.10.3 国庆清北 D3T2 公交车

    题目描述 LYK在玩一个游戏. 有k群小怪兽想乘坐公交车.第i群小怪兽想从xi出发乘坐公交车到yi.但公交车的容量只有M,而且这辆公交车只会从1号点行驶到n号点. LYK想让小怪兽们尽可能的到达自己想 ...

  8. 2017.10.4 国庆清北 D4T1 财富

    (其实这题是luogu P1901 发射站 原题,而且数据范围还比luogu小) 题目描述 LYK有n个小伙伴.每个小伙伴有一个身高hi. 这个游戏是这样的,LYK生活的环境是以身高为美的环境,因此在 ...

  9. 2017.10.7 国庆清北 D7T1 计数

    题目描述 给出m个数a[1],a[2],…,a[m] 求1~n中有多少数不是a[1],a[2],…,a[m]的倍数. 输入输出格式 输入格式: 输入文件名为count.in. 第一行,包含两个整数:n ...

随机推荐

  1. Jenkins安装maven integration plugin失败解决方法

    最近装了一个jenkins准备搞一个自动化测试的持续集成,但是在安装maven integration这个插件时报错,试了几次都是失败! 错误原因如下: javadoc安装失败: java.io.IO ...

  2. 使用lxml解析HTML代码

    做个参考,转自:https://blog.csdn.net/qq_42281053/article/details/80658018

  3. centOS学习part6:安装oracle 11g

    0 大家好.上一章(http://www.cnblogs.com/souvenir/p/3881484.html)我们对oracle在centOS下的安装进行了各项环境准备,本章我们将正式进行oral ...

  4. vue + elementui 使用多选按钮实现单选功能

    CommonRadio.vue <template> <div> <el-checkbox-group v-model="checkList" @ch ...

  5. SAP官网发布的react教程

    大家学习React的时候,用的是什么教程呢?Jerry当时用的阮一峰博客上的入门教程,因为React使用的JSX语法并不是所有的浏览器都支持,所以还得使用browser.js在浏览器端将JSX转换成J ...

  6. 解决mysql跟php不在同一台机器上,编译安装php服务报错问题:configure: error: Cannot find MySQL header files under /application/mysql.

    在编译安装php服务时报错: configure: error: Cannot find MySQL header files under /application/mysql. Note that ...

  7. 七分钟理解 Java 的反射 API

    像java一样,一种具有反射功能的语言.允许开发人员在运行时检查类型.方法.字段.注解等,并在程序运行时决定是否使用. 为此,Java的反射API提供类,类,字段,构造函数,方法,注释和其他. 使用它 ...

  8. C#-判断字符是否是全角半角

    C#字符串的全角是指用二个字节来表示的一个字符 C#字符串的半角是用一个字节来表示的一个字符 这样的话我们就可以用string.length 和System.text.Encoding.Default ...

  9. flask-sqlalchemy用法详解

    一. 安装 $ pip install flask-sqlalchemy 二. 配置 配置选项列表 : 选项 说明 SQLALCHEMY_DATABASE_URI 用于连接的数据库 URI .例如:s ...

  10. 用python实现数据库查询数据方法

    哈喽,好久没来了,最近搞自动化发现了很多代码弯路,特别分享出来给能用到的朋友 因为公司业务的关系,每做一笔功能冒烟测试,我们就要对很多的数据库表中的字段进行校验,当时我就想反正总是要重复的运行这些SQ ...