bzoj4598: [Sdoi2016]模式字符串
Description
Input
Output
点分治统计答案,hash判定当前点到中心的路径是否是由模式串重复得到的串的前/后缀,为保证复杂度,递归至子树大小不足m时结束,时间复杂度O(Tnlog(n/m))
#include<bits/stdc++.h>
int _(){
int x=,c=getchar();
while(c<)c=getchar();
while(c>)x=x*+c-,c=getchar();
return x;
}
typedef unsigned long long u64;
const int N=1e6+,p=;
int T,n,m;
char s1[N],s2[N];
int es[N*],enx[N*],e0[N],ep=,sz[N],SZ,CG;
u64 h1[N],h2[N],ans;
bool ed[N];
void f2(int w,int pa){
sz[w]=;
for(int i=e0[w],u;i;i=enx[i]){
u=es[i];
if(u==pa||ed[u])continue;
f2(u,w);
sz[w]+=sz[u];
}
}
int md,dw;
void f3(int w,int pa){
if(++dw>md)md=dw;
bool is=sz[w]*>=SZ;
for(int i=e0[w],u;i;i=enx[i]){
u=es[i];
if(u==pa||ed[u])continue;
f3(u,w);
if(sz[u]*>SZ)is=;
}
if(is)CG=w;
--dw;
}
int mod[N];
int t1[N],t2[N],a1[N],a2[N];
void f4(int w,int pa,u64 h,int dep){
h=h*p+s1[w];
if(h==h1[dep])++a1[dep[mod]];
if(h==h2[dep])++a2[dep[mod]];
for(int i=e0[w],u;i;i=enx[i]){
u=es[i];
if(u==pa||ed[u])continue;
f4(u,w,h,dep+);
}
}
void f1(int w){
f2(w,);
SZ=sz[w];
md=dw=;
f3(w,);
w=CG;
ed[w]=;
if(md*<m||SZ<m)return;
memset(t1,,sizeof(int)*(m+));
memset(t2,,sizeof(int)*(m+));
for(int i=e0[w];i;i=enx[i]){
int u=es[i];
if(ed[u])continue;
memset(a1,,sizeof(int)*(m+));
memset(a2,,sizeof(int)*(m+));
f4(u,w,s1[w],);
a1[m]=a1[];
a2[m]=a2[];
a1[m+]=a1[];
a2[m+]=a2[];
ans+=a1[]+a2[];
for(int x=;x<m;++x){
ans+=u64(a1[m+-x])*t2[x];
ans+=u64(a2[m+-x])*t1[x];
}
for(int x=;x<m;++x)t1[x]+=a1[x],t2[x]+=a2[x];
}
for(int i=e0[w];i;i=enx[i]){
int u=es[i];
if(!ed[u])f1(u);
}
}
int main(){
for(T=_();T;--T){
ans=;
n=_();m=_();
memset(e0,,sizeof(int)*(n+));
memset(ed,,n+);
scanf("%s",s1+);
for(int i=,a,b;i<n;++i){
a=_();b=_();
es[ep]=b;enx[ep]=e0[a];e0[a]=ep++;
es[ep]=a;enx[ep]=e0[b];e0[b]=ep++;
}
scanf("%s",s2+);
u64 pp=;
for(int i=,j=,k=m;i<=n;++i,pp*=p){
mod[i]=i%m;
h1[i]=s2[j]*pp+h1[i-];
h2[i]=s2[k]*pp+h2[i-];
if(m<++j)j=;
if(!--k)k=m;
}
if(m>)f1();
else for(int i=;i<=n;++i)if(s1[i]==s2[])++ans;
printf("%llu\n",ans);
}
return ;
}
bzoj4598: [Sdoi2016]模式字符串的更多相关文章
- BZOJ4598 [Sdoi2016]模式字符串 【点分治 + hash】
题目 给出n个结点的树结构T,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母A到Z,再给出长度为m 的模式串s,其中每一位仍然是A到z的大写字母.Alice希望知道,有多少对结点< ...
- Bzoj4598: [Sdoi2016]模式字符串 点分治 哈希
国际惯例的题面:这种关于树上路径的题,我也没什么好办法,只好点分治.考虑当前分治重心为root,如何统计经过分治重心的路径的答案.我们令prf[i]表示某个点到root的路径(不含root)已经循环匹 ...
- BZOJ4598: [Sdoi2016]模式字符串(点分治 hash)
题意 题目链接 Sol 直接考虑点分治+hash匹配 设\(up[i]\)表示\(dep \% M = i\)的从下往上恰好与前\(i\)位匹配的个数 \(down\)表示\(dep \% M = i ...
- 【BZOJ4598】[Sdoi2016]模式字符串 树分治+hash
[BZOJ4598][Sdoi2016]模式字符串 Description 给出n个结点的树结构T,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母A到Z,再给出长度为m的模式串s,其中每 ...
- P4075 [SDOI2016]模式字符串
总结 P4075 [SDOI2016]模式字符串 题目描述 给出n个结点的树结构T,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母A到Z,再给出长度为m的模式串s,其中每一位仍然是A到z ...
- [SDOI2016] 模式字符串 (BZOJ4598 & VIJOS1995)
首先直接点分+hash就可以做,每个点用hash判断是否为S重复若干次后的前缀或后缀,每个子树与之前的结果O(m)暴力合并.在子树大小<m时停止分治,则总复杂度为O(nlog(n/m)). 问题 ...
- bzoj 4598: [Sdoi2016]模式字符串
题目描述 给出n个结点的树结构T,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母A到Z,再给出长度为m的模式串s,其中每一位仍然是A到z的大写字母. Alice希望知道,有多少对结点&l ...
- [SDOI2016]模式字符串
Description 给出n个结点的树结构T,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母A到Z,再给出长度为m的模式串s,其中每一位仍然是A到z的大写字母.Alice希望知道,有多 ...
- BZOJ.4598.[SDOI2016]模式字符串(点分治 Hash)
LOJ BZOJ 洛谷 点分治.考虑如何计算过\(rt\)的答案. 记\(pre[i]\)表示(之前的)子树内循环匹配了\(S\)的前缀\(i\)的路径有多少,\(suf[i]\)表示(之前的)子树内 ...
随机推荐
- 学会使用Fidder抓取app的http请求(转)
fidder可以抓取http请求,抓取手机app上面的,自己pc的请求也可以截取,通过这样达到类似浏览器调试的效果,更容易找到问题. 使用原文链接:http://www.cnblogs.com/syf ...
- Alpha冲刺一(1/10)
前言 队名:拖鞋旅游队 组长博客:https://www.cnblogs.com/Sulumer/p/9948330.html 作业博客:https://edu.cnblogs.com/campus/ ...
- JDBC的步骤
使用jdbc步骤 a.导入数据库厂商提供的驱动程序(导入jar包) b.加载驱动程序 Class.forName("驱动程序类") c.获得连接 Connection conn=D ...
- Android响应式UI教程
原文:Responsive UI Tutorial for Android 作者:James Nocentini 译者:kmyhy 2017/5/4 更新说明: 由 James Nocentini 更 ...
- 解决错误:This bundle is invalid - The file extension must be .zip
近期在 iOS 开发中遇到了一个很蛋疼的问题,Xcode 工程中接入了iMessage 壁纸的功能后,每次上传 ipa 包都会显示此包无效,并报上述的错误描述:This bundle is inval ...
- [置顶]
Android 关于SP读取与存储正确打开方式?
一.存储方式分类:SharedPreferences存储 二.SharedPreferences存储 1.特点 ①存储单一数据,例如数值,字符串,布尔 ②文件:/date/date/包名/shared ...
- python3.4 使用BeautifulSoup问题
事情 记得昨儿还是什么时候,反正是以前,肯定安装过BeautifulSoup,只不过当初可能用的是python setup.py install,这是Python2的安装.然而用Python3运行Be ...
- [pandas] SettingWithCopyWarning: A value is trying to be set on a copy of a slice from a DataFrame
转载自https://blog.csdn.net/blackyuanc/article/details/77892784 问题场景: 在读取CSV文件后,在新增一个特征列并根据已有特征修改 ...
- [转载]Unicode中对中文字符的编码
以前写过一篇贴子是写中文在unicode中的编码范围 unicode中文范围,但写的不是很详细,今天再次研究了下unicode,并给出详细的unicode取值范围. 本次研究的unicode对象是un ...
- Java [Leetcode 167]Two Sum II - Input array is sorted
题目描述: Given an array of integers that is already sorted in ascending order, find two numbers such th ...