题意:...

思路:

\(LCA\)乱搞+启发式合并(堆)

#include <bits/stdc++.h>
using namespace std;
const int maxn = 200010;
const int maxm = maxn << 2;
int n,m;
int cnt;
int rt[maxn];
int head[maxn];
int dep[maxn];
int f[maxn][26];
vector<int>v[maxn];
struct edge {
int to;
int nxt;
}e[maxn << 1];
inline void add(int u,int v) {
e[++cnt].to = v;
e[cnt].nxt = head[u];
head[u] = cnt;
return;
}
struct node {
int l;
int r;
int sum;
}t[maxm]; inline int find_lca(int x,int y) {
if(dep[x] < dep[y]) swap(x,y);
int tmp = dep[x] - dep[y];
for(int i = 20;i >= 0; --i) {
if(tmp >> i & 1) {
x = f[x][i];
}
}
if(x == y) return x;
for(int i = 20; i >= 0; --i) {
if(f[x][i] != f[y][i]) {
x = f[x][i];
y = f[y][i];
}
}
return f[x][0];
}
//calc huan
inline void dfs1(int u,int fa) {
for(int i = 1;i <= 20; ++i) {
f[u][i] = f[f[u][i - 1]][i - 1];
}
for(int i = head[u];i;i=e[i].nxt) {
int y = e[i].to;
if(y != fa) {
f[y][0] = u;
dep[y] = dep[u] + 1;
dfs1(y,u);
}
}
}
int tot;
//dui inline void insert(int l,int r,int &now,int x) {
if(!now) {
now = ++tot;
t[now].sum ++;
}
if(l == r) return;
int mid = (l + r) >> 1;
if(x <= mid) {
insert(l,mid,t[now].l,x);
}
else insert(mid + 1,r,t[now].r,x);
} //duihebing
inline int merge(int x,int y) {
if(!x || !y) {
return x | y;
}
int now = ++tot;
t[now].l = merge(t[x].l,t[y].l);
t[now].r = merge(t[x].r,t[y].r);
t[now].sum = t[x].sum + t[y].sum;
return now;
} inline int query(int l,int r,int now,int x) {
if(l == r) return l;
int mid = (l + r) >> 1;
if(t[t[now].l].sum >= x) {
return query(l,mid,t[now].l,x);
}
else {
return query(mid + 1,r,t[now].r,x - t[t[now].l].sum);
}
} inline void dfs2(int x) {
for(int i = 0;i < v[x].size(); ++i) {
insert(1,n,rt[x],v[x][i]);
}
for(int i = head[x];i;i=e[i].nxt) {
int y = e[i].to;
if(y != f[x][0]) {
dfs2(y);
rt[x] = merge(rt[x],rt[y]);
}
}
}
int x,y,q;
#define pb(x) push_back(x)
int main () {
scanf("%d %d",&n,&m);
for(int i = 1;i < n; ++i) {
scanf("%d %d",&x,&y);
add(x,y);
add(y,x);
}
dep[1] = 1;
dfs1(1,0);
for(int i = 1;i <= m; ++i) {
scanf("%d %d",&x,&y);
int FF = find_lca(x,y);
v[x].pb(dep[FF]);
v[y].pb(dep[FF]);
}
dfs2(1);
scanf("%d",&q);
while(q--) {
scanf("%d %d",&x,&y);
int tmp = query(1,n,rt[x],y);
printf("%d\n",max(dep[x] - tmp,0));
}
return 0;
}

[Nowcoder] 保护的更多相关文章

  1. [nowcoder]contest/172/C保护

    C国有n个城市,城市间通过一个树形结构形成一个连通图.城市编号为1到n,其中1号城市为首都.国家有m支军队,分别守卫一条路径的城市.具体来说,对于军队i,他守卫的城市区域可以由一对二元组(xi,yi) ...

  2. Nowcoder 提高组练习赛-R1

    https://www.nowcoder.com/acm/contest/172#question 单人报名300元,五人合报免费,于是就和学弟同学学长们组了一个三世同堂的队伍,高一的学长wzhqwq ...

  3. nowcoder OI 周赛 最后的晚餐(dinner) 解题报告

    最后的晚餐(dinner) 链接: https://www.nowcoder.com/acm/contest/219/B 来源:牛客网 题目描述 \(\tt{**YZ}\)(已被和谐)的食堂实在是太挤 ...

  4. [牛客网NOIP赛前集训营-提高组(第一场)]C.保护

    链接:https://www.nowcoder.com/acm/contest/172/C来源:牛客网 题目描述 C国有n个城市,城市间通过一个树形结构形成一个连通图.城市编号为1到n,其中1号城市为 ...

  5. 为革命保护视力 --- 给 Visual Studio 换颜色

    “为革命,保护视力,预防近视,眼保健操开始......” 这个应该是最老版本的眼保健操了,你听过? 一堆废话 且不说上面这个眼保健操到底有木有用,让眼睛放松下还是很有必要的,尤其是现在天天对着不是手机 ...

  6. Go语言实战 - revel框架教程之CSRF(跨站请求伪造)保护

    CSRF是什么?请看这篇博文“浅谈CSRF攻击方式”,说的非常清楚. 现在做网站敢不防CSRF的我猜只有两种情况,一是没什么人访问,二是局域网应用.山坡网之前属于第一种情况,哈哈,所以至今没什么问题. ...

  7. 用JWT来保护我们的ASP.NET Core Web API

    在上一篇博客中,自己动手写了一个Middleware来处理API的授权验证,现在就采用另外一种方式来处理这个授权验证的问题,毕竟现在也 有不少开源的东西可以用,今天用的是JWT. 什么是JWT呢?JW ...

  8. IBatisNet -- 保护你的配置文件及映射文件信息

    通常情况下我们在使用IBatisNet的时候,配置文件和映射文件都是暴露在外的,如果能进入到服务器,那么你的程序的操作数据库的SQL语句,数据库连接字符串等信息都将很轻松的被看到,这样是很危险的.然而 ...

  9. IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习保护API

    IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习之保护API. 使用IdentityServer4 来实现使用客户端凭据保护ASP.N ...

随机推荐

  1. Dubbo---注册中心

    1.Multicast 注册中心 1.1 Multicast 注册中心   不需要启动  任何中心节点,只要广播地址一样,就可以互相发现. 1.2 1.3 配置   2.zookeeper 注册中心( ...

  2. Java里的参数类型/返回值类型

    参数类型/返回值类型: ##数据类型: ###基本类型: ###引用类型: ####数组 ####类 ####接口 参数类型/返回值类型是类和接口的情况: 1.参数类型是普通类的情况 为什么写成静态, ...

  3. mac上安装mamp集成环境

    深知mac配置环境是个坑,本人之前用的是xampp因为近期需要mongodb扩展,死活装不明白,索性就换了一个集成环境,在网上找了好多,最后选择了mamp 因为正版的要收费,所以在下载了N个以后终于找 ...

  4. Delphi 窗体函数 ShowScrollBar 控制滚动条

    API函数 函数来源:FUNCTION ulong ShowScrollBar(ulong hwnd,ulong wBar,ulong bShow) LIBRARY "user32.dll& ...

  5. Andrdoid中对应用程序的行为拦截实现方式之----从底层C进行拦截

    之前的一篇概要文章中主要说了我这次研究的一些具体情况,这里就不在多说了,但是这里还需要指出的是,感谢一下三位大神愿意分享的知识(在我看来,懂得分享和细致的人才算是大神,不一定是技术牛奥~~) 第一篇: ...

  6. STM32时钟初始化函数SystemInit()详解【转】

    花了一天的时间,总算是了解了SystemInit()函数实现了哪些功能,初学STM32,,现记录如下(有理解错误的地方还请大侠指出): 使用的是3.5的库,用的是STM32F107VC,开发环境RVM ...

  7. 23、css的定位问题

    1.positon:relative相对定位 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" & ...

  8. RabbitMQ使用(二)

    1.消息确认消费 1. 生产者端发消息时,加参数 properties=pika.BasicProperties( delivery_mode=2, # make message persistent ...

  9. 将.opt、.frm、.MYD、.MYI文件放入mysql

    问题:如果数据库没有给sql脚本而且给的.opt..frm..MYD..MYI这些文件,应该如何加载呢???? 解答:首先需要找到“mysql的安装目录/data/”,怎么找?mysql命令执行“sh ...

  10. Bagging vs Boosting vs Stacking

    原文地址:https://www.jianshu.com/p/9dacdc88d3ec Bagging 用于减小方差. 使用训练数据的不同随机子集(大小常等于训练数据,采用不放回的方式进行抽取)来训练 ...