上一页 1 ··· 30 31 32 33 34 35 36 37 38 ··· 58 下一页
摘要: XXVIII.[BZOJ3277]串/CF204E Little Elephant and Strings 这两题是重题,代码改都不改交上去就能A,故放在一起讲。 网上的大多数SA题解都是$O(n\log^2n)$或$O(n\log n)$的复杂度,太令人不爽了。因此,这里有一种复杂度$O(n)$的 阅读全文
posted @ 2021-04-01 11:10 Troverld 阅读(71) 评论(0) 推荐(0) 编辑
摘要: XXVII.[BZOJ4310]跳蚤 我们仍然考虑二分子串。设当前二分的子串从位置$pos$开始,长度为$len$。考虑如何编写check函数。 一个naive的想法便是从前往后枚举所有极大的不存在小于二分串的子串的段,然后将该段数与规定段数作比较。 但是这有点问题——我们发现,这样做每次都是为段中 阅读全文
posted @ 2021-04-01 11:08 Troverld 阅读(54) 评论(0) 推荐(0) 编辑
摘要: XXVI.SP7258 SUBLEX - Lexicographical Substring Search 在上一题中,我们二分了后缀;但这里,我们要二分的是子串。 我们设一个$sum_x$表示有多少本质不同子串的字典序小于等于$sa_i$。显然,它是单调增的。则我们可以二分找出$sum_x$小于询 阅读全文
posted @ 2021-04-01 11:06 Troverld 阅读(48) 评论(0) 推荐(0) 编辑
摘要: XXV.[JSOI2015]串分割 题解 阅读全文
posted @ 2021-04-01 11:05 Troverld 阅读(27) 评论(0) 推荐(0) 编辑
摘要: XXIV.CF123D String 没啥好说的,直接建出笛卡尔树出来,然后统计一下和即可。复杂度$O(n)$,假如你用DC3的话。 代码: #include<bits/stdc++.h> using namespace std; typedef long long ll; const int N= 阅读全文
posted @ 2021-04-01 11:03 Troverld 阅读(49) 评论(0) 推荐(0) 编辑
摘要: XXIII.[NOI2018]你的名字 题解 阅读全文
posted @ 2021-04-01 11:01 Troverld 阅读(40) 评论(0) 推荐(0) 编辑
摘要: XXII.[湖南集训]图森 题解 阅读全文
posted @ 2021-04-01 10:57 Troverld 阅读(42) 评论(0) 推荐(0) 编辑
摘要: XXI.[NOI2016]优秀的拆分 这后缀数组越来越像一个用来求$\operatorname$的工具人了…… 对于一个$\text\(的拆分,我们可以在中间切一刀,变成\)\text\(与\)\text$两半。这时,我们只需要设$a_i$表示以$i$为结尾的$\text$串数量,$b_i$表示以$ 阅读全文
posted @ 2021-04-01 10:55 Troverld 阅读(76) 评论(0) 推荐(0) 编辑
摘要: XX.【模板】后缀自动机 (SAM) 俗话说的好,模板题怎么能用模板水过去呢 我们考虑用建出$ht$数组,然后用单调栈求出每个$ht$最多能向左向右延伸多远(VI.[AHOI2013]差异),然后直接一边扫过求$\max$即可。 复杂度$O(n)$,假如你用DC3的话。但是用倍增实际跑起来也真的超快 阅读全文
posted @ 2021-04-01 10:53 Troverld 阅读(58) 评论(0) 推荐(0) 编辑
摘要: XIX.工艺 /【模板】最小表示法 没啥好说的,直接倍长数组,然后后缀排序即可,道理都在IX.[JSOI2007]字符加密那儿讲过了。 代码: #include<bits/stdc++.h> using namespace std; const int N=600100; int n,m; int 阅读全文
posted @ 2021-04-01 10:52 Troverld 阅读(43) 评论(0) 推荐(0) 编辑
上一页 1 ··· 30 31 32 33 34 35 36 37 38 ··· 58 下一页