【BZOJ3926】诸神眷顾的幻想乡 【广义后缀自动机】
题意
给定一棵树,每个结点有一个颜色,问树上有多少种子串(定义子串为两点上路径颜色的序列)。保证叶子结点<=20
分析
我们可以发现一个结论,任意一个子串一定是以某个叶子结点为根的trie的后缀。我们有注意到,叶子节点最多只有20,那么我们可以将每个叶子结点拿出来,以它为根按照trie树的方式插到广义后缀自动机中。要统计一共有多少子串的话,这样这样建好自动机以后枚举每个状态,然后res+=st[u].len-st[st[u].link].len;
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream> using namespace std;
const int maxn=+;
typedef long long LL;
int val[maxn];
int head[maxn],Next[*maxn],to[*maxn],deg[maxn];
int N,sz,C;
int cnt,cur;
struct state{
int len,link;
int next[];
}st[*maxn]; void init(){
sz=;
memset(head,-,sizeof(head));
cnt=;
cur=;
st[].link=-;
st[].len=;
} void add_edge(int a,int b){
++sz;
to[sz]=b;
Next[sz]=head[a];
head[a]=sz;
} int build_sam(int c,int last){
cur=cnt++;
st[cur].len=st[last].len+;
int p;
for(p=last;p!=-&&st[p].next[c]==;p=st[p].link)
st[p].next[c]=cur;
if(p==-)
st[cur].link=;
else{
int q=st[p].next[c];
if(st[q].len==st[p].len+)
st[cur].link=q;
else{
int clone=cnt++;
st[clone].len=st[p].len+;
st[clone].link=st[q].link;
for(int i=;i<C;i++)
st[clone].next[i]=st[q].next[i];
for(;p!=-&&st[p].next[c]==q;p=st[p].link)
st[p].next[c]=clone;
st[cur].link=st[q].link=clone;
}
}
return cur;
} void dfs(int u,int fa,int las){
int Las=build_sam(val[u],las);
for(int i=head[u];i!=-;i=Next[i]){
int v=to[i];
if(v==fa)continue;
dfs(v,u,Las);
}
return;
} int main(){
scanf("%d%d",&N,&C);
for(int i=;i<=N;i++)
scanf("%d",&val[i]);
int a,b;
init();
for(int i=;i<N;i++){
scanf("%d%d",&a,&b);
add_edge(a,b);
add_edge(b,a);
deg[a]++;deg[b]++;
}
for(int i=;i<=N;i++){
if(deg[i]==){
dfs(i,-,);
}
}
LL ans=;
for(int i=;i<cnt;i++){
int p=st[i].link;
if(p!=-){
ans+=st[i].len-st[p].len;
}
}
printf("%lld\n",ans);
return ;
}
【BZOJ3926】诸神眷顾的幻想乡 【广义后缀自动机】的更多相关文章
- BZOJ3926&&lg3346 ZJOI诸神眷顾的幻想乡(广义后缀自动机)
		
BZOJ3926&&lg3346 ZJOI诸神眷顾的幻想乡(广义后缀自动机) 题面 自己找去 HINT 我们可以把题目拆解成几个部分,首先我们手玩一个结论,从所有的叶子节点出发,遍历整 ...
 - 【BZOJ3926】[Zjoi2015]诸神眷顾的幻想乡 广义后缀自动机
		
[BZOJ3926][Zjoi2015]诸神眷顾的幻想乡 Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝 ...
 - BZOJ 3926 && ZJOI 2015 诸神眷顾的幻想乡 (广义后缀自动机)
		
3926: [Zjoi2015]诸神眷顾的幻想乡 Time Limit: 10 Sec Memory Limit: 512 MB Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽 ...
 - BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡 [广义后缀自动机 Trie]
		
3926: [Zjoi2015]诸神眷顾的幻想乡 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1124 Solved: 660[Submit][S ...
 - 【BZOJ3926】【ZJOI2015】诸神眷顾的幻想乡 广义后缀自动机
		
题目: 题目在这里 思路&做法: 参考的题解 既然只有\(20\)个叶子节点, 那么可以从每个叶子节点往上建一颗\(trie\)树, 然后合并成一棵大的\(trie\)树, 然后构建广义后缀自 ...
 - bzoj 3926: 诸神眷顾的幻想乡 广义后缀自动机
		
题目: Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给 ...
 - BZOJ.3926.[ZJOI2015]诸神眷顾的幻想乡(广义后缀自动机)
		
题目链接 要对多个串同时建立SAM,有两种方法: 1.将所有串拼起来,中间用分隔符隔开,插入字符正常插入即可. 2.在这些串的Trie上建SAM.实际上并不需要建Trie,还是只需要正常插入(因为本来 ...
 - BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡 广义后缀自动机 后缀自动机 字符串
		
https://www.lydsy.com/JudgeOnline/problem.php?id=3926 广义后缀自动机是一种可以处理好多字符串的一种数据结构(不像后缀自动机只有处理一到两种的时候比 ...
 - BZOJ 3926 [Zjoi2015]诸神眷顾的幻想乡 ——广义后缀自动机
		
神奇的性质,叶子节点不超过20个. 然后把这些节点提出来构成一颗新树,那么这些树恰好包含了所有的情况. 所以直接广义后缀自动机. 然后统计本质不同的字符串就很简单显然了. #include <c ...
 - [ZJOI2015]诸神眷顾的幻想乡 广义后缀自动机_DFS_语文题
		
才知道题目中是只有20个叶子节点的意思QAQ.... 这次的广义后缀自动机只是将 last 设为 1, 并重新插入. 相比于正统的写法,比较浪费空间. Code: #include <cstdi ...
 
随机推荐
- spring cloud feign 接口继承以及参数传递的问题
			
1. 优势 可以使用maven 进行访问,实现代码的共享,减少跨服务调用服务编写的问题 2. 使用 定义接口 publicinterfaceIUserService{ @Requ ...
 - PHP实现的多文件上传类及用法示例
			
这篇文章主要介绍了PHP实现的多文件上传类及用法,详细分析了php实现的多文件上传类与具体的使用技巧,需要的朋友可以参考下 1.upFiles.css.php 文件 <?php class Up ...
 - Quick 3.3 的代码资源加密
			
http://cn.cocos2d-x.org/tutorial/show?id=1507 http://cn.cocos2d-x.org/tutorial/show?id=1447 http://b ...
 - Redis简单介绍与安装
			
Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序. Redis有三个主要特点,使它优越于其它键值数据存储系统 - 1) Redis将其数据库完全保存在内 ...
 - 快速排序算法-python实现
			
#-*- coding: UTF-8 -*- import numpy as np def Partition(a, i, j): x = a[i] #将数组的第一个元素作为初始基准位置 p = i ...
 - 黄聪:WordPress默认编辑器可视化切换不见了,非插件导致消失问题
			
1.后台---用户---我的个人资料 2.看看 [可视化编辑器]的[撰写文章时不使用可视化编辑器]项目是不是勾上了 3.去掉保存即可
 - 怎么使用ping命令进行连通性测试
			
关于ping命令的作用: ping 命令有助于验证网络层的连通性!一般进行网络故障排除时,可以使用ping 命令向目标计算机或IP地址发送ICMP回显请求,目标计算机会返回回显应答,如果目标计算机不能 ...
 - 全连接BP神经网络
			
前馈神经网络 前馈神经网络(feedforward neural network)是最朴素的神经网络,通常我们所说的前馈神经网络有两种,一种叫反向传播网络(Back propagation Netwo ...
 - PHP中使用mkdir创建多级目录的方法
			
function mkdirs($dir) { if(!is_dir($dir)) { if(!mkdirs(dirname($dir))){ return false; ...
 - Linux 上通过binlog文件 恢复mysql 数据库详细步骤
			
一.binlog 介绍 服务器的二进制日志记录着该数据库的所有增删改的操作日志(前提是要在自己的服务器上开启binlog),还包括了这些操作的执行时间.为了显示这些二进制内容,我们可以使用mysqlb ...