Hdu-6230 2017CCPC-哈尔滨站 A.Palindrome Manacher 主席树
题意:给你一个字符串,问你满足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 主席树的更多相关文章
- HDU 4729 An Easy Problem for Elfness (主席树,树上第K大)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题意:给出一个带边权的图.对于每一个询问(S , ...
- 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 ...
- 2017中国大学生程序设计竞赛-哈尔滨站 A - Palindrome
Palindrome Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Tota ...
- 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 ...
- 2019CCPC网络赛 C - K-th occurrence HDU - 6704(后缀数组+ST表+二分+主席树)
题意 求区间l,r的子串在原串中第k次出现的位置. 链接:https://vjudge.net/contest/322094#problem/C 思路 比赛的时候用后缀自动机写的,TLE到比赛结束. ...
- 杭电多校HDU 6601 Keen On Everything But Triangle(主席树)题解
题意: 有\(n\)根长度不一的棍子,q次询问,求\([L,R]\)区间的棍子所能组成的周长最长的三角形.棍长\(\in [1, 1e9]\),n\(\in [1, 1e5]\). 思路: 由于不构成 ...
- HDU 6230
Palindrome Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Tota ...
- 2017 ccpc哈尔滨 A题 Palindrome
2017 ccpc哈尔滨 A题 Palindrome 题意: 给一个串\(T\),计算存在多少子串S满足\(S[i]=S[2n−i]=S[2n+i−2](1≤i≤n)\) 思路: 很明显这里的回文串长 ...
- HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)
Super Mario Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
随机推荐
- C# 查找、结束进程 - 通过进程名精确、模糊查找、结束进程
/// <summary> /// 根据“精确进程名”结束进程 /// </summary> /// <param name="strProcName" ...
- JavaScript编程题(一)
使用Javascript脚板输出如图所示的效果页面: 使用document.write()输出水平线 使用循环控制每个水平线的长度 答案:<!doctype html> <html ...
- CNN结构:用于检测的CNN结构进化-分离式方法
前言: 原文链接:基于CNN的目标检测发展过程 文章有大量修改,如有不适,请移步原文. 参考文章:图像的全局特征--用于目标检测 目标的检测和定位中一个很困难的问题是,如何从数以万计的候选 ...
- 分布式机器学习框架:CXXNet
caffe是很优秀的dl平台.影响了后面很多相关框架. cxxnet借鉴了很多caffe的思想.相比之下,cxxnet在实现上更加干净,例如依赖很少,通过mshadow的模板化使得gpu ...
- C# 获得剪贴板内容和 richTextBox部分文本设置颜色
try { MemoryStream vMemoryStream = iData.GetData("Html Format") as MemoryStream; if (vMemo ...
- 如何将一个已有的项目托管到github或是码云上?git的配置
场景一:已有的一个项目,要把它托管到Git上去,步骤和方法如下: 方法一: ①在工程的路径下 : git init 建一个裸仓库. ②远程仓库地址 :将本地的仓库和远程仓库关联 git remote ...
- EF6 mysql配置
如何把一个ef项目 从sqlserver改为mysql 首先在引入了ef的层再引入这两个包,注意两个的版本一定要一样,一定要一样,一定要一样,不然就会报错 MySql.Data.Entity目前的最新 ...
- dd命令测试IO
在实际环境中,测试IO写性能 首先需要实时监测磁盘的IO sar -d interval count 同时对磁盘进行IO压力写 time dd if=/dev/zero of=baa.img bs=1 ...
- codeforces 466B Wonder Room(思维,暴力)
题目 参考了别人的博客,百度来的博客 #include<iostream> #include<string> #include<stdio.h> #include& ...
- vue采坑一:全局API
Vue.set Vue.set( target, key, value ),target不能是 Vue 实例,或者 Vue 实例的根数据对象,因为源码中做了如下判断: var ob = (target ...