Tsinsen-1486:树【Trie树 + 点分治】
暴力部分:
这个题一开始的想法是 n^2 枚举两个点,然后logn维护LCA,在倍增的同时维护异或值和 k 的个数。
s_z_l老爷指导了新的思路,既然这个树只有n^2个LCA,那么枚举LCA,同时向下深搜即可。
标算:
首先点分治,尽力保证树的平衡,然后按照Trie树的性质,贪心,至于k,我们可以把每个节点的值置为like值的最大值,然后在走左右儿子的时候判断一下即可。
点分治时 !vis[E[i].v] && E[i].v != fa 一定不要忘
#include <bits/stdc++.h>
#define rep(i, a, b) for (int i = a; i <= b; i++)
#define REP(i, a, b) for (int i = a; i < b; i++)
#define drep(i, a, b) for (int i = a; i >= b; i--)
#define travel(x) for (int i = G[x]; i; i = E[i].nx)
#define mp make_pair
#define pb push_back
#define clr(x) memset(x, 0, sizeof(x))
#define xx first
#define yy second
using namespace std;
typedef long long i64;
typedef pair<int, int> pii;
//********************************
const int maxn = ;
struct Ed {
int u, v, nx; Ed() {}
Ed(int _u, int _v, int _nx) :
u(_u), v(_v), nx(_nx) {}
} E[maxn << ];
int G[maxn], cnt_e;
void addedge(int u, int v) {
E[++cnt_e] = Ed(u, v, G[u]);
G[u] = cnt_e;
}
int vis[maxn];
pii sta[maxn]; int top;
int rt;
int f[maxn], size[maxn], sum;
void getrt(int x, int fa)
{
f[x] = , size[x] = ;
travel(x) {
if (!vis[E[i].v] && E[i].v != fa) {
getrt(E[i].v, x);
size[x] += size[E[i].v];
f[x] = max(f[x], size[E[i].v]);
}
}
f[x] = max(f[x], sum - size[x]);
if (f[x] < f[rt]) rt = x;
}
int read() {
int l = , s(); char ch = getchar();
while (ch < '' || ch > '') { if (ch == '-') l = -; ch = getchar(); }
while (ch >= ''&& ch <= '') { s = (s << ) + (s << ) + ch - ''; ch = getchar(); }
return l * s;
}
int trie[][], tab[], rootr;
int ntot;
int n, K;
int c[maxn], w[maxn];
int query(int co, int k) {
int ret();
int p = rootr;
if (tab[p] + k < K) return -;
drep(i, , ) {
int id = co >> i & ;
if (trie[p][id ^ ] && tab[trie[p][id ^ ]] + k >= K) ret |= << i, p = trie[p][id ^ ];
else if (!trie[p][id] || tab[trie[p][id]] + k < K) { ret = -; break; }
else p = trie[p][id];
}
return ret;
}
void insrt(int co, int k) {
int p = rootr;
drep(i, , ) {
tab[p] = max(tab[p], k);
int id = co >> i & ;
if (!trie[p][id]) trie[p][id] = ++ntot;
p = trie[p][id];
}
tab[p] = max(tab[p], k);
}
int ans = -;
void dfs_query(int x, int fa, int co, int k) {
sta[++top] = mp(co, k);
ans = max(ans, query(co, k));
for (int i = G[x]; i; i = E[i].nx) if (!vis[E[i].v] && E[i].v != fa)
dfs_query(E[i].v, x, co ^ w[E[i].v], k + c[E[i].v]);
}
/*
void dfs_insrt(int x, int fa, int co, int k) {
insrt(rootr, co, k, 30);
for (int i = G[x]; i; i = E[i].nx) if (!vis[E[i].v] && E[i].v != fa)
dfs_insrt(E[i].v, x, co ^ w[E[i].v], k + c[E[i].v]);
}
*/
void solve(int x) {
vis[x] = ;
rep(i, , ntot) trie[i][] = trie[i][] = , tab[i] = ;
rootr = ;
ntot = ;
if (c[x] >= K) ans = max(ans, w[x]);
insrt(w[x], c[x]);
travel(x) {
if (vis[E[i].v]) continue;
top = ;
dfs_query(E[i].v, x, w[E[i].v], c[E[i].v]);
rep(j, , top) {
sta[j].xx ^= w[x], sta[j].yy += c[x];
insrt(sta[j].xx, sta[j].yy);
}
}
int tmp = sum;
for (int i = G[x]; i; i = E[i].nx) {
if (!vis[E[i].v]) {
rt = ; sum = size[E[i].v] > size[x] ? tmp - size[x] : size[E[i].v];
getrt(E[i].v, );
solve(rt);
}
}
}
int main() {
n = read(), K = read();
rep(i, , n) c[i] = read();
rep(i, , n) w[i] = read();
REP(i, , n) {
int x, y; x = read(), y = read();
addedge(x, y), addedge(y, x);
}
rt = , sum = n, f[] = n + ;
getrt(, );
solve(rt);
printf("%d\n", ans);
return ;
}
Tsinsen-1486:树【Trie树 + 点分治】的更多相关文章
- 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分暴力. 我是傻逼. 题解时间 先不 ...
- [转载]字典树(trie树)、后缀树
(1)字典树(Trie树) Trie是个简单但实用的数据结构,通常用于实现字典查询.我们做即时响应用户输入的AJAX搜索框时,就是Trie开始.本质上,Trie是一颗存储多个字符串的树.相邻节点间的边 ...
- 字典树 Trie树
什么是Trie树? 形如 其中从根节点到红色节点的路径上的字母所连成的字符串即为一个Trie树上所存的字符串. 比如,这个trie树上有ab,abc,bd,dda这些字符串. 至于怎么构建和查找或添加 ...
- 【HDU - 5790 】Prefix(主席树+Trie树)
BUPT2017 wintertraining(15) #7C 题意 求[min((Z+L)%N,(Z+R)%N)+1,max((Z+L)%N,(Z+R)%N)+1]中不同前缀的个数,Z是上次询问的结 ...
- Luogu P2922 [USACO08DEC]秘密消息Secret Message 字典树 Trie树
本来想找\(01Trie\)的结果找到了一堆字典树水题...算了算了当水个提交量好了. 直接插入模式串,维护一个\(Trie\)树的子树\(sum\)大小,求解每一个文本串匹配时走过的链上匹配数和终点 ...
- 字典树 trie树 学习
一字典树 字典树,又称单词查找树,Trie树,是一种树形结构,哈希表的一个变种 二.性质 根节点不包含字符,除根节点以外的每一个节点都只包含一个字符: 从根节点到某一节点,路径上经过的字符串连接起 ...
随机推荐
- Ubuntu下使用rpm 软件包
Ubuntu的软件包格式是deb,如果要安装rpm的包,则要先用alien把rpm转换成deb. sudo apt-get install alien sudo alien xxxx.rpm #将rp ...
- 优化之zencart第一时间修改原始内容
Zen Cart 基本修改指南 Zen Cart,全球顶级B2C商城网站!要想自行搭建一个基本的Zen Cart的网站,这篇文章是绝对不能错过的.目前我已经做了两个B2C网站,但是还是离不开这篇文章的 ...
- Apache无法启动提示the requested operation has failed
主要参考这篇 http://apps.hi.baidu.com/share/detail/15868128 但还是遇到一些问题,记录如下: 1. 配置完成后,restart apache,出现 the ...
- AngularJS中的$http.post与jQuery.post的区别
原文:http://my.oschina.net/tommyfok/blog/287748 很多时候我们需要用ajax提交post数据,angularjs与jq类似,也有封装好的post. 但是jQu ...
- CentOS 6.5添加163源
1.首先备份/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS ...
- Mybatis的<where><foreach><set>等标签详解
sql语句where条件中,需要一些安全判断,例如按性别检索,如果传入的参数是空的,此时查询出的结果很可能是空的,也许我们需要参数为空 时,是查出全部的信息.这是我们可以使用动态sql,增加一个判断, ...
- 转:web_reg_save_param的使用详解
[摘要]利用实际案例说明如何使用Mercury LoadRunner提取包含在 HTML 页内的动态信息并创建参数. [关键词]性能测试,压力测试,Mercury LoadRunner 应用范围 在使 ...
- 转:web_submit_data函数
web_submit_data函数处理无状态或者上下文无关的表单提交.它用来生成表单的GET或POST请求,这些请求与Form自动生成的请求是一样的.发送这些请求时不需要表单上下文. 函数语法:Int ...
- Codevs 5590 A+B 问题 超级版
5590 A+B 问题 超级版 时间限制: 1 s 空间限制: 1000 KB 题目等级 : 青铜 Bronze 题目描述 Description 不用+-*/%计算A+B 输入描述 Input De ...
- Coloring Trees
Coloring Trees time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...