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 ...
随机推荐
- [转]JAVA回调机制(CallBack)详解
看见一篇博客比较通俗的解释了回调机制,转载一下,感谢原文作者Bro__超,原文地址:http://www.cnblogs.com/heshuchao/p/5376298.html 序言 最近学习jav ...
- [Advanced Algorithm] - Inventory Update
题目 依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1 中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物 ...
- Model2
Model1: Model2:
- token的问题汇总
token的作用:认证.授权: 生成:随机码.时间戳.用户 设备 合成: 验证:是否存在.合成验证: 管理:有效期(服务器存储时间or cookie存储过期时间).展期. token生成:或者和用户信 ...
- Can't find variable: SockJS vue项目
用的vue-cli(webpack-simple模板),在开发环境运行(npm run dev),一直都没有问题,突然在ios的safari中调试,出现报错:Can't find variable: ...
- python的自动化测试报告
#coding=utf-8import HTMLTestRunnerimport BeautifulReportimport unittestclass MyTest(unittest.TestCas ...
- 【JavaScript】不使用正则表达式和字符串的方式来解析浏览器的URl地址信息
1.比如我们要获取的网站URl地址是:https://music.163.com/#/playlist?id=2384581760 一般我们能够想到的方式是直接使用正则表达式获取使用字符串直接解析的方 ...
- Java 实现邮件发送功能
1.新建model SendMail.java import java.util.Properties; public class SendMail { // 发送邮件的服务器的IP和端口 priva ...
- 用python实现进度条功能
我在做python的作业:ftp服务时,客户端能够上传.下载文件,这个时候需要编写一个进度条来表示当前的传输进度. 我们可以使用sys,模块来完成任务,需要用到sys.stdout这个方法: 程序示例 ...
- Bootstrap关于表单(二):水平表单
Bootstrap框架默认的表单是垂直显示风格,但很多时候我们需要的水平表单风格(标签居左,表单控件居右) 在Bootstrap框架中要实现水平表单效果,必须满足以下两个条件: 1.在<form ...