【BZOJ4477】[JSOI2015]字符串树(Trie树)
【BZOJ4477】[JSOI2015]字符串树(Trie树)
题面
题解
对于每个点维护其到根节点的所有字符串构成的\(Trie\),显然可持久化一下就很好写了。
然后每次询问就是\(u+v-2lca\),写个树剖维护\(LCA\)就好了。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define MAX 100100
inline int read()
{
	int x=0;bool t=false;char ch=getchar();
	while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
	if(ch=='-')t=true,ch=getchar();
	while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
	return t?-x:x;
}
char ch[MAX][15];
struct Line{int v,next;char *ch;}e[MAX<<1];
int h[MAX],cnt=1;
inline void Add(int u,int v,char *s){e[cnt]=(Line){v,h[u],s};h[u]=cnt++;}
int n,Q,tot;
struct Node{int son[26],v;}t[MAX<<4];
void insert(int &x,char *s,int l,int lim)
{
	t[++tot]=t[x];t[x=tot].v+=1;if(l>lim)return;
	insert(t[x].son[s[l]-'a'],s,l+1,lim);
}
int Query(int x,char *s,int l)
{
	for(int i=1;i<=l;++i)x=t[x].son[s[i]-'a'];
	return t[x].v;
}
int rt[MAX],fa[MAX];
int size[MAX],hson[MAX],top[MAX],dep[MAX];
void dfs1(int u,int ff)
{
	fa[u]=ff;size[u]=1;dep[u]=dep[ff]+1;
	for(int i=h[u];i;i=e[i].next)
	{
		int v=e[i].v;if(v==ff)continue;
		insert(rt[v]=rt[u],e[i].ch,1,strlen(e[i].ch+1));
		dfs1(v,u);size[u]+=size[v];
		if(size[v]>size[hson[u]])hson[u]=v;
	}
}
void dfs2(int u,int tp)
{
	top[u]=tp;
	if(hson[u])dfs2(hson[u],tp);
	for(int i=h[u];i;i=e[i].next)
		if(e[i].v!=fa[u]&&e[i].v!=hson[u])
			dfs2(e[i].v,e[i].v);
}
int LCA(int u,int v)
{
	while(top[u]^top[v])(dep[top[u]]<dep[top[v]])?v=fa[top[v]]:u=fa[top[u]];
	return dep[u]<dep[v]?u:v;
}
int main()
{
	n=read();
	for(int i=1;i<n;++i)
	{
		int u=read(),v=read();scanf("%s",ch[i]+1);
		Add(u,v,ch[i]);Add(v,u,ch[i]);
	}
	dfs1(1,0);dfs2(1,1);
	Q=read();
	while(Q--)
	{
		int u=read(),v=read();scanf("%s",ch[0]+1);
		int l=strlen(ch[0]+1);
		int ans=Query(rt[u],ch[0],l)+Query(rt[v],ch[0],l)-2*Query(rt[LCA(u,v)],ch[0],l);
		printf("%d\n",ans);
	}
	return 0;
}
												
											【BZOJ4477】[JSOI2015]字符串树(Trie树)的更多相关文章
- 牛客练习赛11 假的字符串 (Trie树+拓扑找环)
		
牛客练习赛11 假的字符串 (Trie树+拓扑找环) 链接:https://ac.nowcoder.com/acm/problem/15049 来源:牛客网 给定n个字符串,互不相等,你可以任意指定字 ...
 - Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结
		
Atitit 常见的树形结构 红黑树 二叉树 B树 B+树 Trie树 attilax理解与总结 1.1. 树形结构-- 一对多的关系1 1.2. 树的相关术语: 1 1.3. 常见的树形结构 ...
 - 字典树(Trie树)的实现及应用
		
>>字典树的概念 Trie树,又称字典树,单词查找树或者前缀树,是一种用于快速检索的多叉树结构,如英文字母的字典树是一个26叉树,数字的字典树是一个10叉树.与二叉查找树不同,Trie树的 ...
 - [POJ] #1002# 487-3279 : 桶排序/字典树(Trie树)/快速排序
		
一. 题目 487-3279 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 274040 Accepted: 48891 ...
 - 洛谷$P4585\ [FJOI2015]$火星商店问题 线段树+$trie$树
		
正解:线段树+$trie$树 解题报告: 传送门$QwQ$ $umm$题目有点儿长我先写下题目大意趴$QwQ$,就说有$n$个初始均为空的集合和$m$次操作,每次操作为向某个集合内加入一个数$x$,或 ...
 - luoguP6623 [省选联考 2020 A 卷] 树(trie树)
		
luoguP6623 [省选联考 2020 A 卷] 树(trie树) Luogu 题外话: ...想不出来啥好说的了. 我认识的人基本都切这道题了. 就我只会10分暴力. 我是傻逼. 题解时间 先不 ...
 - BZOJ4477[Jsoi2015]字符串树——可持久化trie树
		
题目描述 萌萌买了一颗字符串树的种子,春天种下去以后夏天就能长出一棵很大的字符串树.字符串树很奇特,树枝上都密密麻麻写满了字符串,看上去很复杂的样子.[问题描述]字符串树本质上还是一棵树,即N个节点N ...
 - 【字符串算法】字典树(Trie树)
		
什么是字典树 基本概念 字典树,又称为单词查找树或Tire树,是一种树形结构,它是一种哈希树的变种,用于存储字符串及其相关信息. 基本性质 1.根节点不包含字符,除根节点外的每一个子节点都包含一个字符 ...
 - [转载]字典树(trie树)、后缀树
		
(1)字典树(Trie树) Trie是个简单但实用的数据结构,通常用于实现字典查询.我们做即时响应用户输入的AJAX搜索框时,就是Trie开始.本质上,Trie是一颗存储多个字符串的树.相邻节点间的边 ...
 - 字典树 Trie树
		
什么是Trie树? 形如 其中从根节点到红色节点的路径上的字母所连成的字符串即为一个Trie树上所存的字符串. 比如,这个trie树上有ab,abc,bd,dda这些字符串. 至于怎么构建和查找或添加 ...
 
随机推荐
- odoo方法
			
一. 类似于前面有个_ 的方法,格式是如下def _getdlvqty(self, cr, uid, ids, field_names, args, context=None): def _get_p ...
 - [HNOI2012]矿场搭建 BZOJ2730 点双+结论
			
Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤点设立救援出口,使得无论哪一 ...
 - UML类图(Unified Modeling Language Class Diagrams)
			
统一建模语言(UML) | 类图 什么是UML? UML是一种用于可视化描述系统,具有广泛用途的建模语言.作为一种标准化的图形语言,在软件工业中被用于软件系统部件的具体化,可视化,结构化描述以及撰写 ...
 - 【第三方插件】使用Topshelf创建Windows服务
			
概述 Topshelf是创建Windows服务的另一种方法,老外的一篇文章Create a .NET Windows Service in 5 steps with Topshelf通过5个步骤详细的 ...
 - Python 语言简介
			
Python是一种计算机程序设计语言.你可能已经听说过很多种流行的编程语言,比如非常难学的C语言,非常流行的Java语言,适合初学者的Basic语言,适合网页编程的JavaScript语言等等. 那P ...
 - [BZOJ3123][Sdoi2013]森林 主席树+启发式合并
			
3123: [Sdoi2013]森林 Time Limit: 20 Sec Memory Limit: 512 MB Description Input 第一行包含一个正整数testcase,表示当 ...
 - Page结构
			
SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的.在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成:db_id,fi ...
 - exchange 2010 的两个错误
			
最近公司要搭建邮件服务器 过程中 碰到两个问题,记录下来. 引以为戒 . 1,登陆界面能出来 但是无论输入什么都显示 乱码.问题原因 身份验证有问题. 如图所示: 改成这个,然后 重启 iis 就可 ...
 - SpringBoot入门学习记录(一)
			
最近,SpringBoot.SpringCloud.Dubbo等框架非常流行,作为Coder里的一名小学生,借着改革开放的东风,自然也是需要学习学习的,于是将学习经历记录于此,以备日后查看. 官网:h ...
 - 3Sum(or k_Sum)
			
Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find ...