CF17E Palisection——优秀的综合计数题
题意翻译
给定一个长度为n的小写字母串。问你有多少对相交的回文子 串(包含也算相交) 。 输入格式
第一行是字符串长度n(1<=n<=2*10^6),第二行字符串 输出格式
相交的回文子串个数%51123987
题解
首先,我们要知道一个串有多少个回文串。
1.manacher,
枚举回文中心可以计算出所有的回文串个数
(i+p[i]-1)-(i-p[i]+1)+1
然后我们怎么知道多少相交的回文串呢?
计数问题要转化成有分界点的问题,便于利用乘法加法原理等。——lyd
这个相交显然不好处理,也没有分界点。
所以采用容斥。
2.容斥,所有的回文串对数-不相交的对数
不相交的话,分界点一下就出来了。我们可以枚举分解点试试。
因为这样便于划分成区间处理。
而直接相交处理不容易。
3.枚举分界点统计
①
c[x][0]以x开始的回文串个数,c[x][1]以x为末尾的回文串个数
这两个可以区间加,差分处理。
具体来说,一个点为中心的所有回文串,会给(i-p[i]+1)~(i)位置开始的回文串多一个。c[x][1]同理。
这里的差分,不用树状数组....并不需要动态维护修改查询
直接数组差分即可。最后从左到右累加,一边统计c[x][0/1]
然后令,pre[x],为c[x][1]的前缀和
②
对于枚举的分界点i(2<=i<=n) ,ans-=pre[i-1]*c[i][0]
根据回文串开始和结束位置的唯一性,这样一定不重不漏。
相当于把每个字符串和前面不相交的字符串都统计了一遍。
代码:注意%=mod
#include<bits/stdc++.h>
#define ri register int
#define il inline
using namespace std;
typedef long long ll;
const int N=+;
const int mod=;
int n,m;
int p[*N];
char a[N],b[*N];
il void manacher(){
p[]=;
int mx=,id=;
for(ri i=;i<=m;i++){
p[i]=min(p[*id-i],mx-i);
if(p[i]<) p[i]=;
int j=i-p[i],k=i+p[i];
while(j>=&&k<=m&&b[j]==b[k]){
p[i]++;
j--;k++;
}
if(i+p[i]->mx){
mx=i+p[i]-;
id=i;
}
}
}
ll f[N],g[N];
ll ans,tot,sum;
ll c[N][],pre[N];
il void add1(int x,ll c){
f[x]+=c;
}
il void add2(int x,ll c){
g[x]+=c;
}
signed main()
{
scanf("%d",&n);
scanf("%s",a+);
b[++m]='#';
for(ri i=;i<=n;i++){
b[++m]=a[i];
b[++m]='#';
}
manacher();
for(ri i=;i<=m;i++){
if(i&) (tot+=p[i]/)%=mod;//%mod;//#
else (tot+=p[i]/)%=mod;//%mod;//not
}
ans=(tot*(tot-)/)%mod;//%mod;
for(ri i=;i<=n;i++){
add1(i-p[i*]/+,(ll)),add1(i+,(ll)-);
if(i!=n) add1(i-p[i*+]/+,(ll)),add1(i+,(ll)-); } for(ri i=;i<=n;i++){
c[i][]=(c[i-][]+f[i])%mod;
} for(ri i=;i<=n;i++){
add2(i,(ll)),add2(i+(p[i*]/),(ll)-);
if(i!=n) add2(i+,(ll)),add2(i+p[i*+]/+,(ll)-);
}pre[]=;
for(ri i=;i<=n;i++){
c[i][]=(c[i-][]+g[i])%mod;
pre[i]=(pre[i-]+c[i][])%mod;
if(i>=){
ll now=(pre[i-]*c[i][])%mod;
ans=(ans+mod-now)%mod;
}
}
printf("%lld",ans);
return ;
}
总结:
突破口:容斥。划分分界点统计。
CF17E Palisection——优秀的综合计数题的更多相关文章
- CF17E Palisection(manacher/回文树)
CF17E Palisection(manacher/回文树) Luogu 题解时间 直接正难则反改成求不相交的对数. manacher求出半径之后就可以差分搞出以某个位置为开头/结尾的回文串个数. ...
- ZOJ 3955 Saddle Point 校赛 一道计数题
ZOJ3955 题意是这样的 给定一个n*m的整数矩阵 n和m均小于1000 对这个矩阵删去任意行和列后剩余一个矩阵为M{x1,x2,,,,xm;y1,y2,,,,,yn}表示删除任意的M行N列 对于 ...
- UOJ#428. 【集训队作业2018】普通的计数题
#428. [集训队作业2018]普通的计数题 模型转化好题 所以变成统计有标号合法的树的个数. 合法限制: 1.根标号比子树都大 2.如果儿子全是叶子,数量B中有 3.如果存在一个儿子不是叶子,数量 ...
- 一道综合渗透题引发的updatexml()注入思考
MYSQL数据库updatexml报错注入UPDATEXML (XML_document, XPath_string, new_value); 第一个参数:XML_document是String格式, ...
- D. Count the Arrays 计数题
D. Count the Arrays 也是一个计数题. 题目大意: 要求构造一个满足题意的数列. \(n\) 代表数列的长度 数列元素的范围 \([1,m]\) 数列必须有且仅有一对相同的数 存在一 ...
- 【NOIP2017提高A组模拟9.7】JZOJ 计数题
[NOIP2017提高A组模拟9.7]JZOJ 计数题 题目 Description Input Output Sample Input 5 2 2 3 4 5 Sample Output 8 6 D ...
- noip模拟44[我想我以后会碰见计数题就溜走的]
noip模拟44 solutions 这一场抱零的也忒多了,我也只有45pts 据说好像是把几套题里面最难的收拾出来让我们考得 好惨烈啊,这次的考试我只有第一题骗了40pts,其他都抱零了 T1 Em ...
- FJOI2020 的两道组合计数题
最近细品了 FJOI2020 的两道计数题,感觉抛开数据范围不清还卡常不谈里面的组合计数技巧还是挺不错的.由于这两道题都基于卡特兰数的拓展,所以我们把它们一并研究掉. 首先是 D1T3 ,先给出简要题 ...
- 「10.16晚」序列(....)·购物(性质)·计数题(DP)
A. 序列 考场不认真读题会死..... 读清题就很简单了,分成若干块,然后块内递增,块外递减,同时使最大的块长为$A$ B. 购物 考场思路太局限了,没有发现性质, 考虑将$a_{i}$,排序前缀和 ...
随机推荐
- 笨办法学Python - 习题8-10: Printing & Printing, Printing
目录 1.习题 8: 打印,打印 2.习题 9: 打印,打印,打印 3.习题 10: 那是什么? 3.1.转义序列: 4.习题总结: 1.习题 8: 打印,打印 学习目标:继续学习 %r 的格式化输出 ...
- Tomcat部署与使用
Tomcat简介 Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache.Sun和其他一些公司及个人共同开发 ...
- 使用python实现用微信远程控制电脑
首先,我们要先看看微信远程控制电脑的原理是什么呢? 我们可以利用Python的标准库控制本机电脑,然后要实现远程的话,我们可以把电子邮件作为远程控制的渠道,我们用Python自动登录邮箱检测邮件,当我 ...
- Beta阶段基于spec评论作品
组名:杨老师粉丝群 组长:乔静玉 组员:吴奕瑶 刘佳瑞 公冶令鑫 杨磊 刘欣 张宇 卢帝同 一.测试目标:拉格朗日2018——飞词 下面是他们的小游戏在运行时的一些截图画面: 1.开始界面 ...
- Task 6.3 冲刺Two之站立会议1
今天是二次冲刺的第一天,由于第一阶段已经大概完成了软件的主体功能和框架,我主要看了一下同学们提出的视频和音质的问题,想办法做出了相应的改善.另外我们的功能还是比较单一的,要对主界面进行一定的扩充,所以 ...
- Centos7 虚拟机复制后网卡问题 Job for network.service failed
在运行“/etc/init.d/network restart”命令时,出现错误“Job for network.service failed. See 'systemctl status netwo ...
- [2017BUAA软工]第3次个人作业
软工第3次个人作业--案例分析 一. 调研,评测 1.软件的bug(至少两个,不少于40字) 测试软件: 必应词典移动端 测试平台:iPhone 6 bug1 对于翻译功能中的图片翻译功能,必应词典是 ...
- 【问底】徐汉彬:PHP7和HHVM的性能之争 (真是学到了很多)
来源:http://www.csdn.net/article/2014-12-25/2823234 作者:徐汉彬 摘要:近日,PHP7和HHVM的性能之争成为了一个讨论热点,但毫无疑问,它们都在提升P ...
- Rotate Array II
Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, the array ...
- PHP面试经常被提到的问题
1. Include 与 require的区别,require和require_once的效率哪个高? PHP在遇到include时就解释一次,如果页面中出现10次include,php就解释10次, ...