bzoj 3620 暴力KMP

十分暴力的KMP,枚举左端点,在向右侧推进的同时,取较小的la保证条件,n方暴力

#include<bits/stdc++.h>
#define rep(i,j,k) for(int i=j;i<=k;i++)
#define inf 0x3fffffff
using namespace std;
const int N=20000;
char s[N];int l,k,nxt[N],la[N],ans;
int main(){
    freopen("3620.in","r",stdin);
    freopen("3620.out","w",stdout);
    scanf("%s",s+1);l=strlen(s+1);scanf("%d",&k);ans=0;
    rep(i,1,l){
        nxt[i]=i-1,la[i]=inf;
        rep(ii,i,l-1){
            int j=nxt[ii];while(j>=i&&s[ii+1]!=s[j+1])j=nxt[j];
            if(s[ii+1]==s[j+1]) ++j;nxt[ii+1]=j;

            if(nxt[ii+1]-i+1<k)la[ii+1]=inf;else{
                la[ii+1]=min(la[nxt[ii+1]],nxt[ii+1]);
                if(la[ii+1]-i+1<=(ii+1-i)>>1) ++ans;}
        }
    }
    printf("%d",ans); return 0;
}

原文地址:https://www.cnblogs.com/asdic/p/9645957.html

时间: 2024-11-09 06:43:58

bzoj 3620 暴力KMP的相关文章

[BZOJ 3620] 似乎在梦中见过的样子 【KMP】

题目链接:BZOJ - 3620 题目分析 这道题使用 KMP 做 O(n^2) 的暴力就能过. 首先,我们依次枚举字串左端点 l ,然后从这个左端点开始向后做一次 KMP. 然后我们枚举右端点 r ,符合条件的右端点 r 就是 S[l..r] 这一段的一个前缀和后缀相同,并且这一部分的长度 x 要满足 k <= x < (r - l + 1) / 2. 我们就使用 KMP 的 Next 数组来找这个前缀,直接从 Next[r] 向前找最坏情况会导致变成 O(n^3) ,所以我们应该优化一下:

BZOJ 3670 &amp;&amp; BZOJ 3620 &amp;&amp; BZOJ 3942 KMP

最近感到KMP不会啊,以前都是背板的现在要理解了. 1 #include <iostream> 2 #include <cstring> 3 #include <cstdio> 4 #include <algorithm> 5 using namespace std; 6 const int Maxn=16000; 7 8 char S[Maxn]; 9 int k,P[Maxn],Ans; 10 11 12 inline void Kmp(char * S

hdu2087 剪花布条 暴力/KMP

在字符串中不可重叠地寻找子串数量,暴力/KMP 1 #include<stdio.h> 2 #include<string.h> 3 4 int main(){ 5 char a[1005],b[1005]; 6 while(scanf("%s",a)!=EOF&&a[0]!='#'){ 7 scanf("%s",b); 8 getchar(); 9 int la=strlen(a),lb=strlen(b); 10 int

bzoj 1493 暴力

我们可以枚举每个点,然后求出这个点到其余点最小消耗的代价,求出比t小的且距离最大的更新答案. /************************************************************** Problem: 1295 User: BLADEVIL Language: C++ Result: Accepted Time:4572 ms Memory:3944 kb ***************************************************

BZOJ 3620: 似乎在梦中见过的样子 [KMP 暴力]

和我签订契约,成为魔法少女吧 题意:求所有形似于A+B+A 的子串的数量 , 且len(A)>=k,len(B)>=1 位置不同其他性质相同的子串算不同子串,位置相同但拆分不同的子串算同一子串 竟然是暴力........ 枚举从哪里开始,和上题一样了 只不过本题$l$确定后一个$r$只能贡献一次,所以向前找第一个$2*j \le i-1$的位置判断$j \ge k$就行了 #include <iostream> #include <cstdio> #include &l

bzoj 3620 似乎在梦中见过的样子(KMP)

[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3620 [题意] 给定一个字符串,统计有多少形如A+B+A的子串,要求A>=K,B>=1. [思路] 枚举左端点i,对字符串s[i..n]统计答案. 放个指针,然后枚举右端点j,如果指针超过长度一半则沿fail向前找,设指针为k.如果匹配则满足s[i..k]==s[j-k+1..j],最后判定一下长度限制. [代码] 1 #include<cstdio> 2 #inclu

【BZOJ 3620】 3620: 似乎在梦中见过的样子 (KMP)

3620: 似乎在梦中见过的样子 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 755  Solved: 445 Description "Madoka,不要相信 QB!"伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Modoka 的一个噩梦,也同时是上个轮回中所发生的事.为了使这一次 Madoka 不再与 QB签订契约,Homura 决定在刚到学校的第一天就解决 QB.然而,QB 也是有许多替身的(但

bzoj 3670 动物园 - kmp - 动态规划

Description 近日,园长发现动物园中好吃懒做的动物越来越多了.例如企鹅,只会卖萌向游客要吃的.为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决定开设算法班,让动物们学习算法. 某天,园长给动物们讲解KMP算法. 园长:“对于一个字符串S,它的长度为L.我们可以在O(L)的时间内,求出一个名为next的数组.有谁预习了next数组的含义吗?” 熊猫:“对于字符串S的前i个字符构成的子串,既是它的后缀又是它的前缀的字符串中(它本身除外),最长的长度记作next[i].

bzoj 3620: 似乎在梦中见过的样子

Description "Madoka,不要相信 QB!"伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Modoka 的一个噩梦,也同时是上个轮回中所发生的事.为了使这一次 Madoka 不再与 QB签订契约,Homura 决定在刚到学校的第一天就解决 QB.然而,QB 也是有许多替身的(但在第八话中的剧情显示它也有可能是无限重生的),不过,意志坚定的 Homura 是不会放弃的--她决定 消灭所有可能是 QB 的东西.现在,她已感受到附近的状态,并且