HDU 6191 Query on A Tree ( 2017广西邀请赛 && 可持久化Trie )
题意 : 给你一棵树、树上的每个点都有点权、之后有若干次问询、每次问询给出一个节点编号以及一个整数 X 、问你以给出节点为根的子树中哪个节点和 X 异或最大、输出这个值
分析 :
看到这种树上异或最值的问题
可以考虑使用 Trie 来解决
首先涉及到子树
我们可以利用 DFS 序来构造出每个根的子树
DFS 序有很好的性质、其子树的所有节点必定是序列中连续的一段
那么我们就可以对这个 DFS 序列建立可持久化 Trie
然后通过类似前缀和减法的方式得到问询节点子树表示的区间中
所有数组成的 Trie 、然后通过贪心的方法来得到最大异或值
#include<bits/stdc++.h>
using namespace std;
;
);
int root[maxn];
int sz[maxNode];
];
;
int newNode()
{
totNode++;
memset(ch[totNode], , sizeof(ch[totNode]));
sz[totNode] = ;
return totNode;
}
inline void Insert(int F, int C, int val)
{
F = root[F], C = root[C];
; i>=; i--){
;
if(!ch[C][bit]){
ch[C][bit] = newNode();
ch[C][!bit] = ch[F][!bit];
sz[ ch[C][bit] ] = sz[ ch[F][bit] ];
}
C = ch[C][bit], F = ch[F][bit];
sz[C]++;
}
}
int Query(int x, int y, int val)
{
;
; i>=; i--){
;
)
ret += (<<i),
y = ch[y][!c],
x = ch[x][!c];
else x = ch[x][c], y = ch[y][c];
}
return ret;
}
struct EDGE{ int v, w, nxt; }Edge[maxn];
;
int weight[maxn];
inline void Edge_init(int n)
{
memset(sz, , sizeof(sz));
memset(ch, , sizeof(ch));
memset(Head, -, sizeof(Head));
EdgeCnt = ;
}
inline void AddEdge(int From, int To, int Weight)
{
Edge[EdgeCnt].v = To;
Edge[EdgeCnt].w = Weight;
Edge[EdgeCnt].nxt = Head[From];
Head[From] = EdgeCnt++;
}
;
int st[maxn], en[maxn];
void DFS(int v)
{
st[v] = squLen;
squ[squLen++] = v;
; i=Edge[i].nxt){
int Eiv = Edge[i].v;
DFS(Eiv);
}
en[v] = squLen-;
}
int main(void)
{
int n, q;
while(~scanf("%d %d", &n, &q)){
squLen = ;
totNode = ;
Edge_init(n);
; i<=n; i++) scanf("%d", &weight[i]);
; i<=n-; i++){
int Fa; scanf("%d", &Fa);
AddEdge(Fa, i+, weight[i]);
}
DFS();
root[] = ch[][] = ch[][] = ;
; i<squLen; i++) root[i] = newNode();
; i<squLen; i++)
Insert(i-, i, weight[squ[i]]);
while(q--){
int v, x;
scanf("%d %d", &v, &x);
printf(, en[v], x));
}
}
;
}
HDU 6191 Query on A Tree ( 2017广西邀请赛 && 可持久化Trie )的更多相关文章
- HDU 6191 Query on A Tree(可持久化Trie+DFS序)
Query on A Tree Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Othe ...
- [hdu 6191] Query on A Tree
Query on A Tree Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Othe ...
- HDU 6191 Query on A Tree(字典树+离线)
Query on A Tree Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Othe ...
- HDU 6191 Query on A Tree(可持久化Trie)
题意 \(n\) 个点的有根树,根为 \(1\) .每个点有点权,有 \(q\) 个询问,每次询问以 \(u\) 为根的子树的点的点权中异或 \(x\) 所得的最大值是多少. 思路 求出整棵树的 \( ...
- HDU - 6191 Query on A Tree (可持久化字典树/字典树合并)
题目链接 题意:有一棵树,树根为1,树上的每个结点都有一个数字x.给出Q组询问,每组询问有两个值u,x,代表询问以结点u为根的子树中的某一个数与x的最大异或值. 解法一:dfs序+可持久化字典树.看到 ...
- 2017广西邀请赛 Query on A Tree (可持续化字典树)
Query on A Tree 时间限制: 8 Sec 内存限制: 512 MB提交: 15 解决: 3[提交][状态][讨论版] 题目描述 Monkey A lives on a tree. H ...
- 2017ACM/ICPC广西邀请赛-重现赛
HDU 6188 Duizi and Shunzi 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6188 思路: 签到题,以前写的. 实现代码: #inc ...
- S - Query on a tree HDU - 3804 线段树+dfs序
S - Query on a tree HDU - 3804 离散化+权值线段树 题目大意:给你一棵树,让你求这棵树上询问的点到根节点直接最大小于等于val的长度. 这个题目和之前写的那个给你一棵 ...
- hdu 4836 The Query on the Tree(线段树or树状数组)
The Query on the Tree Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
随机推荐
- Oacle常用语句
1.建表语句 ) NOT NULL, region_id ) NOT NULL, salesperson_id ) NOT NULL, ) NOT NULL, ) NOT NULL, tot_orde ...
- 从入门到自闭之Python字典如何使用
字典: 定义:dict dict = {"key":"value"} -- 键值对 作用:存储大量数据,数据和数据起到关联作用 所有的操作都是通过键来完成 键: ...
- 使用parquet-hadoop.jar包解析hive parquet文件时,遇到FIXED_LEN_BYTE_ARRAY转换为Decimal 以及 INT96转换为timestamp问题
在使用parquet-hadoop.jar包解析parquet文件时,遇到decimal类型的数据为乱码,具体解决方法如下: 使用parquet-Hadoop.jar解析httpfs服务提供的parq ...
- Spring Boot全局支持CORS(跨源请求)
import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet. ...
- js获取url(request)中的参数
index.htm?参数1=数值1&参数2=数值2&参数3=数据3&参数4=数值4&...... 静态html文件js读取url参数,根据获取html的参数值控制htm ...
- CentOS7搭建FastDFS V5.11分布式文件系统(二)
1.CentOS7 FastDFS搭建 前面已下载好了要用到的工具集,下面就可以开始安装了: 如果安装过程中出现问题,可以下载我提供的,当前测试可以通过的工具包: 点这里点这里 1.1 安装libfa ...
- python之itertools
Python的内建模块itertools提供了非常有用的用于操作迭代对象的函数. count 创建一个迭代器,生成从n开始的连续整数,如果忽略n,则从0开始计算(注意:此迭代器不支持长整数) 如果超出 ...
- Java定义栈结构,实现入栈、出栈操作
package com.example.demo; import java.util.ArrayList; public class Stack { ArrayList<Object> l ...
- centos 7 Network 脚本
#!/bin/sh #主动启动网卡 interface=$() ifup $interface #获取当前网络信息 default_route=$(ip route show) default_int ...
- c++ 实现https网页上的图片爬取
一.主要的原理 我们通过发送一个http请求,获得目标网页的html源代码,然后通过正则表达式获取到图片的URL,把该网页的所有的图片都保存到一个文件夹,这就是整个软件的流程. 二.具体的实践 现在很 ...