题面

题意:给你一个字符串,问你满足s[i]=s[2n-i]=s[2n+i-2]的子串(这子串长度为3n-2)有多少个,原字符串长度<=5e5

题解:对于这种子串,其实要满足2个回文,跑过一次Manacher后,len[i]表示以i向两边扩展最远的回文串长度,

那么对于答案,实际就是统计满足下列条件(i,j)的对数

i  <= j

j - i <= len[i]

j - i <= len[j]

移项就是

i >= j -  len[j]

j <= i + len[i]

那么相当于,枚举i,询问(i,i+len[i])区间内,有多少个数(这里指权值 j - len[j])小于等于i

就是问区间内小于某个数的个数,那就是主席树裸题(好像其他人都写的树状树状ORZ)

 #include<bits/stdc++.h>
#define N 500505
using namespace std;
int sum[N*],rt[N*],lc[N*],rc[N*];
int a[N],b[N],len[N],p,node_cnt,cnt,value[N];
char s[N];
void build(int &t,int l, int r)
{
t=++node_cnt;
sum[t]=;
if (l==r) return;
int mid=(l+r)>>;
build(lc[t],l,mid);
build(rc[t],mid+,r);
}
int modify(int o,int l,int r)
{
int oo = ++node_cnt;
lc[oo]=lc[o]; rc[oo]=rc[o]; sum[oo]=sum[o]+;
if (l==r) return oo;
int mid=(l+r)>>;
if (p<=mid) lc[oo]=modify(lc[oo],l,mid);
else rc[oo]=modify(rc[oo],mid+,r);
return oo;
}
int query(int u,int v,int l,int r,int k)
{
int ans,mid=((l+r)>>);
if (r<=k) return sum[v]-sum[u];
if (l>k) return ;
ans=query(lc[u],lc[v],l,mid,k);
if (mid<k) ans=ans+query(rc[u],rc[v],mid+,r,k);
return ans;
}
void manacher()
{
int pos=,R=;
for (int i=;i<=cnt;i++)
{
if (i<R) len[i]=min(len[*pos-i],R-i); else len[i]=;
while (<=i-len[i]&&i+len[i]<=cnt&&s[i-len[i]]==s[i+len[i]]) len[i]++;
if (i+len[i]>R) {pos=i;R=i+len[i];}
}
for(int i=;i<=cnt;i++)
{
a[i]=i-len[i]+;
b[i]=a[i];
}
}
int main()
{
int k, n, q, nn, v, l, r, x,T;
scanf("%d\n",&T);
while (T--)
{
scanf("%s",s+);
cnt=strlen(s+);
manacher();
sort(b+,b++cnt);
nn=unique(b+,b+cnt+)-b-;
node_cnt=;
build(rt[],,nn);
for (int i=;i<=cnt;i++)
{
p=lower_bound(b+,b+nn+,a[i])-b;
rt[i]=modify(rt[i-],,nn);
}
long long ans=;
for (int i=;i<=cnt;i++)
{
x=lower_bound(b+,b+nn+,i)-b;
if (x==nn+) x--;
if (b[x]>i) x--;
if(x==) continue;
if(min(len[i]+i-,cnt)<i+) continue;
ans=ans+query(rt[i],rt[min(len[i]+i-,cnt)],,nn,x);
}
printf("%lld\n",ans);
}
}

Hdu-6230 2017CCPC-哈尔滨站 A.Palindrome Manacher 主席树的更多相关文章

  1. HDU 4729 An Easy Problem for Elfness (主席树,树上第K大)

    转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents    by---cxlove 题意:给出一个带边权的图.对于每一个询问(S , ...

  2. HDU - 6231 K-th Number (2017CCPC哈尔滨站 二分+尺取法)

    Alice are given an array A[1..N] with N numbers. Now Alice want to build an array B by a parameter K ...

  3. 2017中国大学生程序设计竞赛-哈尔滨站 A - Palindrome

    Palindrome Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Tota ...

  4. HDU 4729 An Easy Problem for Elfness(主席树)(2013 ACM/ICPC Asia Regional Chengdu Online)

    Problem Description Pfctgeorge is totally a tall rich and handsome guy. He plans to build a huge wat ...

  5. 2019CCPC网络赛 C - K-th occurrence HDU - 6704(后缀数组+ST表+二分+主席树)

    题意 求区间l,r的子串在原串中第k次出现的位置. 链接:https://vjudge.net/contest/322094#problem/C 思路 比赛的时候用后缀自动机写的,TLE到比赛结束. ...

  6. 杭电多校HDU 6601 Keen On Everything But Triangle(主席树)题解

    题意: 有\(n\)根长度不一的棍子,q次询问,求\([L,R]\)区间的棍子所能组成的周长最长的三角形.棍长\(\in [1, 1e9]\),n\(\in [1, 1e5]\). 思路: 由于不构成 ...

  7. HDU 6230

    Palindrome Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Tota ...

  8. 2017 ccpc哈尔滨 A题 Palindrome

    2017 ccpc哈尔滨 A题 Palindrome 题意: 给一个串\(T\),计算存在多少子串S满足\(S[i]=S[2n−i]=S[2n+i−2](1≤i≤n)\) 思路: 很明显这里的回文串长 ...

  9. HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

随机推荐

  1. 【Oracle】DG中物理备库、快照备库的相互转换

    一.物理备库切换快照备库 1. 如果正在运行日志应用,先停止 ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL; 2. 确保数据库为MOUN ...

  2. 时序分析:串匹配-KMP算法

    图像处理与模式识别的教科书使用大量的章节来描述空域的模式识别方法.从图像底层特征提取.贝叶斯方法到多层神经网络方法,一般不讨论到对象随时间变化的情况,视频处理应用和在线学习方法使研究对象开始向时域延伸 ...

  3. Linux各发行版配置总结

    Ubuntu 14.04(该版本下亲测好用) 1.修改开机启动项和默认启动项 sudo gedit /boot/grub/grub.cfg(修改前最好备份一个) 2.登陆界面图片的修改 /usr/sh ...

  4. jquery-pjax

    项目介绍: Pjax是jQuery的一个插件,Pjax即pushState + Ajax,是实现无刷新Ajax加载并解决浏览器前进和后退问题的一个开源实现. 在2012年8月28日发布0.9版本. P ...

  5. AFNetworking源码解析-https证书相关

    本篇说说安全相关的AFSecurityPolicy模块,AFSecurityPolicy用于验证HTTPS请求的证书,先来看看HTTPS的原理和证书相关的几个问题. HTTPS HTTPS连接建立过程 ...

  6. 触发a标签

    var aLink = document.createElement("a"); aLink.download = ''; aLink.href = url; if (docume ...

  7. 单链表每k个节点为一组进行反转(最后不满k个时不反转)

    public class LinkReverse2 { public static Node mhead=null; public static Node mtail=null; public sta ...

  8. 用Python获取摄像头并实时控制人脸

    实现流程从摄像头获取视频流,并转换为一帧一帧的图像,然后将图像信息传递给opencv这个工具库处理,返回灰度图像(就像你使用本地静态图片一样) 程序启动后,根据监听器信息,使用一个while循环,不断 ...

  9. H3C交换机配置常用命令(转)

    1.配置文件相关命令 [Quidway]display current-configuration //显示当前生效的配置 [Quidway]display saved-configuration / ...

  10. freemarker使用map替换字符串中的值demo2

    package demo01; import java.io.IOException;import java.io.OutputStreamWriter;import java.io.StringWr ...