码迷,mamicode.com
首页 > 其他好文 > 详细

[CF1168B] Good Triple

时间:2020-04-04 20:30:14      阅读:68      评论:0      收藏:0      [点我收藏+]

标签:for   证明   rip   solution   fine   lin   min   using   lang   

给出 \(01\)\(s\),求数对 \([l,r]\) 个数,使得能找到至少一对 \(x,k\),使 \(1\le x,k \le |s|\)\(l\le x<x+2k \le r\)\(s[x]=s[x+k]=s[x+2k]\)

Solution

考虑一个暴力,对于所有的 \(l\),暴力找到最小的能满足条件的 \(r\)

容易证明 \(r\) 是关于 \(l\) 单调的,于是倒序扫描 \(l\) 即可

#include <bits/stdc++.h>
using namespace std;

#define int long long
const int N = 1000005;

char s[N];
int n,ans,r;

signed main() {
    cin>>s+1;
    n=strlen(s+1);
    r=n+1;
    for(int i=n;i>=1;--i) {
        for(int j=1;i+2*j<=n;j++) {
            if(s[i]==s[i+j]&&s[i]==s[i+2*j]) {
                r=min(r,i+2*j);
                break;
            }
        }
        ans+=max(n-r+1,0ll);
    }
    cout<<ans;
}

[CF1168B] Good Triple

标签:for   证明   rip   solution   fine   lin   min   using   lang   

原文地址:https://www.cnblogs.com/mollnn/p/12633635.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!