【NOI2016】优秀的拆分【后缀数组】【ST表】【关键点】【调和级数复杂度】【差分】

传送门

题意:如果一个字符串可以拆分为AABB的形式,其中A和B是任意非空字符串,则我们这种拆分是优秀的。求给定串的所有子串的拆分方案数之和。

N≤30000N \leq30000N30000

本来是个神仙题

但明明一个O(nlogn)O(nlogn)O(nlogn)的题为啥只出300003000030000啊(而且只有一个点)……搞不懂

显然求出所有位置作为AA的开始和结束位置有多少个然后乘一下加起来

接下来是个神奇做法

枚举我们要求的长度lenlenlen,然后每隔lenlenlen记录一个关键点

这样每个长度为2∗len2*len2len的AA都恰好经过两个相邻关键点,我们用这两个关键点计算贡献。

在这里插入图片描述
用后缀数组算出它们向前和向后的最长的相同长度

如果中间没有相交

在这里插入图片描述那么是没有贡献的

如果有相交,把相交这段标为蓝色\textcolor{blue}{蓝色}
在这里插入图片描述
我们发现A可以等于蓝色\textcolor{blue}{蓝色}+绿色\textcolor{green}{绿色}绿+紫色\textcolor{purple}{紫色}

挪到后面也可以等于绿色\textcolor{green}{绿色}绿+紫色\textcolor{purple}{紫色}+蓝色\textcolor{blue}{蓝色}

中间随便截一段也是合法的

用个差分即可

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cctype>
#include <algorithm>
#define MAXN 30005
using namespace std;
typedef long long ll;
int LOG[MAXN];
char s[MAXN];
int n;
struct SuffixArray
{int sa[MAXN],rk[MAXN],tp[MAXN];int c[MAXN],ht[MAXN];int st[MAXN][20];int m;void Rsort(){for (int i=1;i<=m;i++) c[i]=0;for (int i=1;i<=n;i++) ++c[rk[i]];for (int i=1;i<=m;i++) c[i]+=c[i-1];for (int i=n;i>=1;i--) sa[c[rk[tp[i]]]--]=tp[i];}void build(){memset(rk,0,sizeof(rk));memset(sa,0,sizeof(sa));memset(tp,0,sizeof(tp));m='z';for (int i=1;i<=n;i++) rk[i]=s[i],tp[i]=i;Rsort();for (int w=1,p=0;p<n;w<<=1,m=p){p=0;for (int i=n-w+1;i<=n;i++) tp[++p]=i;for (int i=1;i<=n;i++) if (sa[i]>w) tp[++p]=sa[i]-w;Rsort();swap(rk,tp);rk[sa[1]]=p=1;for (int i=2;i<=n;i++)if (tp[sa[i]]==tp[sa[i-1]]&&tp[sa[i]+w]==tp[sa[i-1]+w]) rk[sa[i]]=p;else rk[sa[i]]=++p;}int k=1;for (int i=1;i<=n;i++){if (k) --k;int j=sa[rk[i]-1];while (s[i+k]==s[j+k]) ++k;ht[rk[i]]=k;}memset(st,0,sizeof(st));for (int i=1;i<=n;i++) st[i][0]=ht[i];for (int j=1;j<20;j++)for (int i=1;i+(1<<(j-1))<=n;i++)st[i][j]=min(st[i][j-1],st[i+(1<<(j-1))][j-1]);}inline int query_st(int l,int r){int t=LOG[r-l+1];return min(st[l][t],st[r-(1<<t)+1][t]);}inline int query(int x,int y){if (rk[x]>rk[y]) swap(x,y);return query_st(rk[x]+1,rk[y]);}
}A,B;
#define lcp B.query
#define lcs A.query
int p[MAXN],q[MAXN];
int main()
{LOG[0]=-1;for (int i=1;i<MAXN;i++) LOG[i]=LOG[i>>1]+1;int T;scanf("%d",&T);while (T--){scanf("%s",s+1);n=strlen(s+1);A.build();reverse(s+1,s+n+1);B.build();    for (int i=1;i<=n;i++) p[i]=q[i]=0;for (int len=1;len<=n;len++)for (int i=len;i+len<=n;i+=len){int j=i+len;int a=min(lcp(n-i+1,n-j+1),len),b=min(lcs(i,j),len);if (a+b<=len) continue;int s=a+b-len-1;++p[i-a+1];--p[i-a+s+2];++q[i-a+2*len];--q[i-a+s+2*len+1];   }for (int i=1;i<=n;i++) p[i]+=p[i-1],q[i]+=q[i-1];ll ans=0;for (int i=1;i<n;i++) ans+=(ll)q[i]*p[i+1];printf("%lld\n",ans);}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315177.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

剑指 Offer 43. 1~n 整数中 1 出现的次数(数位dp)

思路&#xff1a;就是数位dp&#xff0c;dp[idx][sum][limit]代表&#xff0c;到idx位&#xff0c;前面有sum个0&#xff0c;有没有limit限制&#xff1b; class Solution { public:int dp[20][50][2];int len; int pos[20];int countDigitOne(int n) {for(int i0;i<15;i)f…

Windows新终端中玩转ASCII和Emoji游戏的正确姿势

前一段时间&#xff0c;我搬运了几个Windows Terminal中玩游戏的视频.Windows Terminal - 动图GIF作背景图Windows Terminal - 母牛说HiWindows Terminal - 字符水族箱今天我来给大家展示一下具体的玩法~Emoji版双人碰碰球目前有个现成的 .NET core 项目可以直接用&#xff0c;…

剑指 Offer 38. 字符串的排列(有重复元素的排列)

思路&#xff1a;dfs 暴搜 class Solution { public:vector<string> permutation(string s) {vector<string> a;function<bool(char,int,int)> check[&](char x,int st,int idx){if(st>idx) return false;for(int ist;i<idx;i) if(s[i]x) return …

Pool construction UVA - 1515 最小割模型

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个n∗mn*mn∗m的矩阵&#xff0c;包含字符#和.&#xff0c;将#变成.的代价是ddd&#xff0c;将.变成#的代价是fff&#xff0c;让后将#和.隔开的代价是bbb&#xff0c;现在让你用最小的代价将#和.隔开&…

【洛谷P4707】重返现世【扩展Min-Max容斥】【dp】

传送门 题意&#xff1a;NNN种物品&#xff0c;每次第iii种产生概率为piM\frac{p_i}{M}Mpi​​,∑piM\sum p_iM∑pi​M。求生成KKK种不同物品的期望时间 模998244353998244353998244353 N≤1000,M≤10000,N−K≤10N \leq1000,M \leq 10000,N-K\leq10N≤1000,M≤10000,N−K≤10…

nowcoder Forsaken的数列 fhq-treap

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 很明显的数据结构了&#xff0c;splaysplaysplay当然能写&#xff0c;但是fhq−treapfhq-treapfhq−treap更加简洁易懂。 考虑第一个操作&#xff0c;无非就是分裂出[1,pos−1][1,pos-1][1…

HTTP协议支持的方法

方法说明支持的HTTP协议版本GET获取资源1.0,1.1POST传输实体主体1.0,1.1PUT传输文件1.0,1.1DELETE删除文件1.0,1.1OPTIONS询问支持的方法1.1HEAD获取报文首部1.0,1.1TRACE追踪路径1.1CONNECT要求用隧道协议连接代理1.1LINK建立和资源之间的联系1.0UNLINE断开连接关系1.0在这里例…

我与微软的不解之缘 - 我的Insider Dev Tour 2019讲师之旅

作者&#xff1a;Lamond Lu大家好&#xff0c;我是陆楠&#xff0c;来自北京盛安德科技发展有限公司青岛分公司&#xff0c;今年非常有幸作为讲师参加了微软Insider Dev Tour烟台站的活动&#xff0c;我主讲了如何使用最新的微软开发工具开发调试NodeJS项目。与微软结缘与大多数…

【bzoj2555】Substring【后缀平衡树入门】

传送门 &#xff08;bzoj上不去我也很无奈啊&#xff09; 题意&#xff1a;维护一个字符串&#xff0c;支持后面加字符串&#xff0c;给定串询问出现次数。强制在线。 数据范围&#xff1a;暴力跑不过 前置知识&#xff1a;重量平衡树 众所周知&#xff0c;平衡树都用了一…

.NET Core 3.0之深入源码理解Kestrel的集成与应用(一)

写在前面ASP.NET Core 的 Web 服务器默认采用Kestrel&#xff0c;这是一个基于libuv(一个跨平台的基于Node.js的异步I/O库)的跨平台、轻量级的Web服务器。在开始之前&#xff0c;先回顾一下.NET Core 3.0默认的main()方法模板中&#xff0c;我们会调用Host.CreateDefaultBuilde…

HTTP状态码的类别

状态码类别类别原因短语1XX信息性状态码接受的请求正在处理2XX成功状态码请求正常处理完毕3XX重定向状态码需要进行附加操作以完成请求4XX客户端错误状态码服务器无法处理请求5XX服务器错误状态码 服务器处理请求出错 HTTP状态码的数量高达60余种&#xff0c;下面为大家介绍比…

P2596 [ZJOI2006]书架 无旋treap 按照排名分裂

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 实现如下操作&#xff1a; 思路&#xff1a; fhq-treap板子辣&#xff0c;不要被他的编号误导了&#xff0c;我们还是需要按照排名来分裂&#xff0c;从上到下标号1−n1-n1−n即可&#xff0c;注意在按照…

【水】几个网络流图论模型的记录

DAG相关 最小路径覆盖 定义&#xff1a;最少不重路径覆盖DAG 初始时每个点是独立的 之后每次加一条边把两个点连到一起 因为只能用一次&#xff0c;所以是个最大匹配 最小路径覆盖N-拆点后最大匹配\text{最小路径覆盖N-拆点后最大匹配}最小路径覆盖N-拆点后最大匹配 最小链…

surging 微服务引擎 2.0 会有多少惊喜?

surging 微服务引擎从2017年6月至今已经有两年的时间&#xff0c;这两年时间有多家公司使用surging 服务引擎&#xff0c;并且有公司搭建了CI/CD&#xff0c;并且使用了k8s 集群&#xff0c;这里我可以说下几家公司的服务搭建情况&#xff0c;公司名不便透露&#xff0c;我们就…

MySQL中存在索引但不能索引的经典场景(笔记)

以%开头的LIKE查询不能使用B-Tree索引 这个是因为B-Tree数的结构决定的&#xff0c;一般推荐使用全文索引来解决类似的全文检索的问题数据类型出现隐式转换的时候也不会使用索引不满足最左前缀原则的情况下也不会使用到索引如果全表扫描比索引快的话&#xff0c;则不使…

Codeforces Round #630 (Div. 2) E. Height All the Same 排列组合

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 由于n,mn,mn,m都很大&#xff0c;不难猜到这是一个公式题。 首先化简题目中的两个操作&#xff0c;第二个操作就是可以让奇偶性相同的位置的高度相同。第一个操作虽然是改变相邻两个的奇偶…

【洛谷P4719】动态DP【LCT】【矩阵】

之前的后缀平衡树其实没完&#xff0c;只是过于鬼畜就弃了 传送门 题意&#xff1a;带修改点权的最大独立集 N≤1e5N \leq 1e5N≤1e5 一个没啥用的模板&#xff0c;不过适合练习LCT 先写出方程 f(u,0)∑v∈son(u)max{f(v,0),f(v,1)}f(u,0)\sum_{v \in son(u)}max\{f(v,0),f…

对产品质量的一点思考

不管是做产品还是做项目&#xff0c;也不管是采用瀑布模型还是敏捷开发&#xff0c;我们都有一个终极目标&#xff0c;就是能按时交付质量可靠的功能&#xff0c;其中质量尤为重要。本文是我对产品质量的一点思考&#xff0c;如果您所在的团队代码质量很高&#xff0c;很少出BU…

操作系统-学习笔记

王道操作系统&#xff1a;有道云笔记 欢迎评论给意见&#xff01;

Codeforces Round #630 (Div. 2) F. Independent Set 树形dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一棵树&#xff0c;求这棵树的边导出子图中独立集的数量和&#xff0c;独立集大小可以为000。 思路&#xff1a; 先考虑普通的独立集数量怎么求&#xff0c;无非就是分情况讨论一下选根还是不选根&…