CodeForces - 1238D(思惟)

题意

https://vjudge.net/problem/CodeForces-1238Dios

若是一个字符串的每一个字母,属于至少一个(长度大于1)的回文串,则称这个字符串为good。c++

一个长度为n的字符串s(只由字母A,B组成),问s的子串中有多少个good字符串spa

思路

发现只有XYX这种交错的串或者XX…X才多是good串。.net

直接作比较难,咱们考虑求不合法的串。blog

因此咱们先正着遍历一遍字符串,找出XXXXY这种,即经过s[i]!=s[i-1]计算前面相同字符的个数,即为不合法串的个数(XY,XXY,XXXY,XXXXY都不合法)ci

再倒着遍历一遍,找出XYYYY这种,即经过s[i]!=s[i+1]计算后面相同字符的葛素,即为不合法串的个数(XY,XYY,XYYY,XYYYY)字符串

但咱们也能够发现,这样作会把XY这种减两遍,事实是正着算算成了XY,倒着算算成了YX,因此再遍历一遍,把XY这种交错的个数算出来。get

长度为1的串确定不合法,因此用总的串(n-1+1)*(n-1)/2 减去上面不合法的状况,再加上多减的XY。string

代码

#include<bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
#define ll long long
const int N=200005;
const int mod=1e9+7;
const double eps=1e-8;
const double PI = acos(-1.0);
#define lowbit(x) (x&(-x))
int main()
{
    std::ios::sync_with_stdio(false);
    ll n;
    cin>>n;
    string s;
    cin>>s;
    ll ans=n*(n-1)/2,cnt=1;
    for(int i=1;i<n;i++)//XXXXY
    {
        if(s[i]==s[i-1]) cnt++;
        else ans-=cnt,cnt=1;
    }
    cnt=1;
    for(int i=n-2;i>=0;i--)
    {
        if(s[i]==s[i+1]) cnt++;
        else ans-=cnt,cnt=1;
    }
    for(int i=1;i<n;i++)
        if(s[i]!=s[i-1])
            ans++;
    cout<<ans<<endl;
    return 0;
}
相关文章
相关标签/搜索