题意:给出一个字符串,问其中有多少个子串恰好为\(uvu\)的形式。其中,\(u\)非空,\(v\)的长度恰好为\(l\)。

\(n \leq 5 \times 10^4\)

我们设两个后缀的起点分别为\(a,b \, (a < b)​\),那么,它们能贡献一个合法的子串当且仅当\(lcp(a,b) + l \geq b - a​\)。这样,我们得到了\(O(n^2)​\)的暴力。

由于\(lcp(a,b)\)和\(b-a\)没有什么关系,所以我们考虑枚举\(b-a\)。设\(b-a = s\)。那么,答案中\(u\)的长度就要满足\(|u| \geq s - l\)。因此,我们可以忽视长度小于\(s-l\)的字符串。

考虑这样一种做法:枚举\(s-l\),并且把字符串分成\(\left\lceil \frac {n} {s-l} \right\rceil\)段,于是产生\(O \left(\frac {n} {s-l} \right)\)个端点。我们发现,所有满足\(|u| \geq s-l\)的子串\(u\)都至少覆盖一个端点。因此,我们枚举所有端点,并计算所有覆盖它的子串对答案的贡献。为了避免重复计算,我们只在一个子串覆盖的最右边的端点计算它的贡献。

现在,我们已有一个端点\(p\),那么另一个\(u\)的起点就在\(p + s\)。那么,只要求出\(lcp(p,p+s)\)和\(lcs(p,p+s)\),我们就能得出所有以\(p\)为其覆盖的最后一个端点的可能的\(u\)的数量。

因为\(H_n = \ln n + O(1)\),所以如果使用\(O(1)\)的lcs和lcp,时间复杂度是\(O(n \log n)\)的。(但博主写了\(O(n \log^2 n)\)。

#include <bits/stdc++.h>
using namespace std;
const int N = 80010, BAS = 233;
typedef unsigned long long ull;
ull has[N],mul[N];
long long ans;
int n,l;
char s[N];
ull gethas(int a,int b) {
return has[b] - has[a-1] * mul[b-a+1];
}
bool check(int a,int b,int c,int d) {
return gethas(a,b) == gethas(c,d);
}
int lcs(int a,int b) {
int l = 0, r = min(a,b), ret = 0, mid;
while (l <= r) {
mid = (l + r) >> 1;
if (check(a-mid+1,a,b-mid+1,b)) l = mid + 1, ret = mid;
else r = mid - 1;
}
return ret;
}
int lcp(int a,int b) {
int l = 0, r = min(n - a + 1, n - b + 1), ret = 0, mid;
while (l <= r) {
mid = (l + r) >> 1;
if (check(a,a+mid-1,b,b+mid-1)) l = mid + 1, ret = mid;
else r = mid - 1;
}
return ret;
}
int main() {
scanf("%d",&l);
scanf("%s",s+1);
n = strlen(s+1);
for (int i = 1 ; i <= n ; ++ i)
has[i] = has[i-1] * BAS + s[i];
mul[0] = 1;
for (int i = 1 ; i <= n ; ++ i)
mul[i] = mul[i-1] * BAS;
for (int s = 1 ; s <= n ; ++ s) {
for (int i = 1, j = 1 + s + l, a, b ; j <= n ; i += s, j += s) {
a = lcs(i,j);
b = lcp(i,j);
if (b > s) continue;
ans += max(0,a + b - s);
}
}
printf("%lld\n",ans);
return 0;
}

小结:一些基本套路都不会……字符串能力有待提高。

【做题】BZOJ2534 L-gap字符串——调和级数的更多相关文章

  1. 「BZOJ 2534」 L - gap字符串

    「BZOJ 2534」 L - gap字符串 题目描述 有一种形如 \(uv u\) 形式的字符串,其中 \(u\) 是非空字符串,且 \(v\) 的长度正好为 \(L\), 那么称这个字符串为 \( ...

  2. l洛谷 P3926 SAC E#1 - 一道不可做题 Jelly

    P3926 SAC E#1 - 一道不可做题 Jelly 题目背景 SOL君(炉石主播)和SOL菌(完美信息教室讲师)是好朋友. 题目描述 SOL君很喜欢吃蒟蒻果冻.而SOL菌也很喜欢蒟蒻果冻. 有一 ...

  3. SDOI2016 R1做题笔记

    SDOI2016 R1做题笔记 经过很久很久的时间,shzr终于做完了SDOI2016一轮的题目. 其实没想到竟然是2016年的题目先做完,因为14年的六个题很早就做了四个了,但是后两个有点开不动.. ...

  4. 【做题】BZOJ2342 双倍回文——马拉车&并查集

    题意:有一个长度为\(n\)的字符串,求它最长的子串\(s\)满足\(s\)是长度为4的倍数的回文串,且它的前半部分和后半部分都是回文串. \(n \leq 5 \times 10^5\) 首先,显然 ...

  5. Sam做题记录

    Sam做题记录 Hihocoder 后缀自动机二·重复旋律5 求一个串中本质不同的子串数 显然,答案是 \(\sum len[i]-len[fa[i]]\) Hihocoder 后缀自动机三·重复旋律 ...

  6. 【Leetcode 做题学算法周刊】第二期

    首发于微信公众号<前端成长记>,写于 2019.11.05 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 20 ...

  7. 课后选做题-MyOD

    课后选做题-MyOD od命令的了解 功能 od命令用于将指定文件内容以八进制.十进制.十六进制.浮点格式或ASCII编码字符方式显示,通常用于显示或查看文件中不能直接显示在终端的字符.od命令系统默 ...

  8. [JSOI2019]节日庆典 做题心得

    [JSOI2019]节日庆典 做题心得 一个性质有趣的字符串题 这要是在考场上我肯定做不出来吧 一开始还以为要 SAM 什么的暴力搞,没想到只用到了 \(Z\) 函数 -- 也是我生疏了罢 (学了啥忘 ...

  9. NOIP初赛:完善程序做题技巧

    最近写的文章好像还很多的.那么今天我们来讨论NOIP初赛的题型--完善程序.完善程序相对是比较难的题目了.全卷100分,完善程序占了大概26分,占比非常大.如果和英语考试试卷做比较,相当于首字母填空( ...

  10. SAM 做题笔记(各种技巧,持续更新,SA)

    SAM 感性瞎扯. 这里是 SAM 做题笔记. 本来是在一篇随笔里面,然后 Latex 太多加载不过来就分成了两篇. 标 * 的是推荐一做的题目. trick 是我总结的技巧. I. P3804 [模 ...

随机推荐

  1. caffe编译环境的错误:..build_release/src/caffe/proto/caffe.pb.h:23:35: fatal error: google/protobuf/arena.h: 没有那个文件

    在搭建caffe的环境时出现错误: .build_release/src/caffe/proto/caffe.pb.h:23:35: fatal error: google/protobuf/aren ...

  2. Usefull Resources

    Sql Server Profiler 1. http://www.cnblogs.com/Fooo/archive/2013/02/19/2916789.html 2. http://5439255 ...

  3. html5-嵌入图片

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  4. python二 总结--函数-- 装饰器

    装饰器是什么? 有什么用? 为什么要用? 真的有用吗? 1.装饰器: 装饰器: 定义:本质是函数,(装饰其他函数)就是为其他函数添加附加功能. 原则:1.不能修改被装饰的函数的源代码          ...

  5. Nginx配置基础-location

    location表达式类型 ~ 表示执行一个正则匹配,区分大小写~* 表示执行一个正则匹配,不区分大小写^~ 表示普通字符匹配.使用前缀匹配.如果匹配成功,则不再匹配其他location.= 进行普通 ...

  6. ManyToManyField 增加记录

    class BOMView(View): def get(self,request): obj=BOMForm() return render(request,'bom.html',{'obj':ob ...

  7. Docker学习笔记之docker volume 容器卷的那些事(一)

    预览目录 volume 方式 相关用例 使用方式 使用 volume driver bind mount 方式 相关用例 使用方式 配置selinux标签 配置macOS的安装一致性 tmpfs 方式 ...

  8. 容器学习笔记之CentOS7安装Docker(安装指定版本的Docker,加速,卸载)

    0x00 概述 Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE. 社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如经过官方测试认证过 ...

  9. Redis Desktop Manager连接Redis

    1.注释redis.conf文件中的:bind 127.0.0.1修改为自己的IP 2.ifconfig查看自己的虚拟机ip 3.拿到IP后,返回Windows,开启cmd,通过telnet命令,测试 ...

  10. P4219 [BJOI2014]大融合(LCT)

    P4219 [BJOI2014]大融合 对于每个询问$(u,v)$所求的是 ($u$的虚边子树大小+1)*($v$的虚边子树大小+1) 于是我们再开个$si[i]$数组表示$i$的虚边子树大小,维护一 ...