893F - Subtree Minimum Query

题意

给出一棵树,每次询问 \(x\) \(k\),求以 \(x\) 为根结点的子树中的结点到结点 \(x\) 的距离小于等于 \(k\) 的结点权值最小值。

分析

可持久化线段树,对每个结点都建树,然后尽可能复用子孙结点的线段树。

对于一般的线段树,我们并不需要记录左右子结点的标号,因为如果当前节点标号为 \(rt\) ,则左右子结点标号为 \(2 * rt\) 和 \(2 * rt + 1\) 。对于本题,若有 \(u\) 是 \(v\) 的父亲,那么理论上 \(u\) 在 \(v\) 所建好的线段树的基础上只会影响一条链的结点,为保证不影响在 \(v\) 结点建好的线段树,对于产生影响的结点我们新建一个结点,并设置左右子结点,对于其它的结点,我们都可以复用,即将左右子结点直接指向已经建好的线段树的结点即可。

code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e5 + 10;
const int INF = 2e9 + 10;
int a[N], sz, rot[N * 50], dep[N];
struct node {
int l, r, val;
void init() { l = r = 0; val = INF; }
}nd[N * 50]; vector<int> G[N]; void update(int p, int val, int l, int r, int &rt) {
nd[rt = ++sz].init();
nd[rt].val = min(nd[rt].val, val);
if(l != r) {
int m = l + r >> 1;
if(p <= m) update(p, val, l, m, nd[rt].l);
else update(p, val, m + 1, r, nd[rt].r);
nd[rt].val = min(nd[nd[rt].l].val, nd[nd[rt].r].val);
}
} int query(int L, int R, int l, int r, int rt) {
if(L <= l && R >= r) return nd[rt].val;
int m = l + r >> 1;
int res = INF;
if(L <= m) res = query(L, R, l, m, nd[rt].l);
if(R > m) res = min(res, query(L, R, m + 1, r, nd[rt].r));
return res;
} int mergeUp(int u, int v) {
if(!u) return v;
if(!v) return u;
int t = ++sz;
nd[t].init();
nd[t].l = mergeUp(nd[u].l, nd[v].l);
nd[t].r = mergeUp(nd[u].r, nd[v].r);
nd[t].val = min(nd[u].val, nd[v].val);
return t;
} void dfs(int fa, int u) {
dep[u] = dep[fa] + 1;
update(dep[u], a[u], 1, N, rot[u]);
for(int v : G[u]) {
if(v != fa) {
dfs(u, v);
rot[u] = mergeUp(rot[u], rot[v]);
}
}
} int main() {
nd[0].init();
int n, r;
scanf("%d%d", &n, &r);
for(int i = 1; i <= n; i++) {
scanf("%d", &a[i]);
}
for(int i = 1; i < n; i++) {
int u, v;
scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
dfs(0, r);
int q, lst = 0;
scanf("%d", &q);
while(q--) {
int x, k, b, c;
scanf("%d%d", &b, &c);
x = ((b + lst) % n) + 1;
k = (c + lst) % n;
lst = query(dep[x], min(dep[x] + k, N), 1, N, rot[x]);
printf("%d\n", lst);
}
return 0;
}

Codeforces 893F - Subtree Minimum Query的更多相关文章

  1. [cf contest 893(edu round 33)] F - Subtree Minimum Query

    [cf contest 893(edu round 33)] F - Subtree Minimum Query time limit per test 6 seconds memory limit ...

  2. CF893F Subtree Minimum Query 解题报告

    CF893F Subtree Minimum Query 输入输出格式 输入格式: The first line contains two integers \(n\) and \(r\) ( \(1 ...

  3. Subtree Minimum Query CodeForces - 893F (线段树合并+线段树动态开点)

    题目链接:https://cn.vjudge.net/problem/CodeForces-893F 题目大意:给你n个点,每一个点有权值,然后这n个点会构成一棵树,边权为1.然后有q次询问,每一次询 ...

  4. Educational Codeforces Round 33 (Rated for Div. 2) F. Subtree Minimum Query(主席树合并)

    题意 给定一棵 \(n\) 个点的带点权树,以 \(1\) 为根, \(m\) 次询问,每次询问给出两个值 \(p, k\) ,求以下值: \(p\) 的子树中距离 \(p \le k\) 的所有点权 ...

  5. [CF893F] Subtree Minimum Query

    Description: 给定一棵树,每次询问某点子树中到其不超过k的所有点的最小点权 强制在线 Hint: \(n,m\le 10^5\) Solution: 看到题目第一反应是以深度为下标,dfs ...

  6. 2019.01.19 codeforces893F.Subtree Minimum Query(线段树合并)

    传送门 线段树合并菜题. 题意简述:给一棵带点权的有根树,多次询问某个点ppp子树内距离ppp不超过kkk的点的点权最小值,强制在线. 思路: 当然可以用dfsdfsdfs序+主席树水过去. 然而线段 ...

  7. CF893F:Subtree Minimum Query(线段树合并)

    Description 给你一颗有根树,点有权值,m次询问,每次问你某个点的子树中距离其不超过k的点的权值的最小值.(边权均为1,点权有可能重复,k值每次询问有可能不同,强制在线) Input 第一行 ...

  8. EC Round 33 F. Subtree Minimum Query 主席树/线段树合并

    这题非常好!!! 主席树版本 很简单的题目,给一个按照指定节点的树,树上有点权,你需要回答给定节点的子树中,和其距离不超过k的节点中,权值最小的. 肯定首先一想,按照dfs序列建树,然后按照深度为下标 ...

  9. CF893F Subtree Minimum Query 主席树

    如果是求和就很好做了... 不是求和也无伤大雅.... 一维太难限制条件了,考虑二维限制 一维$dfs$序,一维$dep$序 询问$(x, k)$对应着在$dfs$上查$[dfn[x], dfn[x] ...

随机推荐

  1. 转:java泛型总结

    转自:http://www.cnblogs.com/lwbqqyumidi/p/3837629.html 一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public ...

  2. sql基础题目测试及正确答案

    在网上做了一套基本的sql题目,以下是我的写的答案,适合基础人员练练 --创建测试数据 use test create table Student(S# varchar(10),Sname nvarc ...

  3. iOS 友盟推送,应用内推送启动图推送闪动黑屏,插屏推送方法报错

    以前都是用的极光推送,应公司需求要求使用友盟推送,为了以后是有分享都适用,,, 友盟推送文档,下载demo 感觉比极光用着要简单顺手 一切就绪后,开始发送消息测试,,,,,搞了半天没有发过来消息 原来 ...

  4. 关于mysql使用命令行时出现Data too long for column的解决方案:

    方法一: 1,在mysql根目录下找到my.ini文件: 2:将其中sql-mode中的STRICT_TRANS_TABLES这个属性去掉: 3:重启mysql的服务(注意注销电脑不会重启mysql服 ...

  5. 模板引擎(smarty)知识点总结三

    阔别了几个月,小杨又来分享php知识.话不多说,言归正传,今天继续带来smarty的知识点. -----------------smarty  assign append 详解 对于这两个的区别和联系 ...

  6. WPF单位真的与分辨率无关吗?

    转载自http://www.cnblogs.com/helloj2ee/archive/2009/04/21/1440709.htm WPF从发布之日起,一直将"分辨率无关(resoluti ...

  7. 在亚马逊linux环境上装mysql+添加启动项

    安装mysql sudo yum install mysql sudo yum install mysql-server sudo yum install mysql-devel 添加到系统启动项su ...

  8. Golang 网络爬虫框架gocolly/colly 三

    Golang 网络爬虫框架gocolly/colly 三 熟悉了<Golang 网络爬虫框架gocolly/colly一>和<Golang 网络爬虫框架gocolly/colly二& ...

  9. CSS开发规范

    虽然很久之前整理过一份简单的CSS规范,但是当时写的也不是很全面,有些细节也没有照顾到.记录一份较详细的版本,以备不时之需. 命名规范 [强制] class一律使用小写字母+下划线格式命名 例: cl ...

  10. SQLServer 查看SQL语句的执行时间

    在MSSQL Server中通过查看SQL语句执行所用的时间,来衡量SQL语句的性能. 通过设置STATISTICS我们可以查看执行SQL时的系统情况.选项有PROFILE,IO ,TIME.介绍如下 ...