LINK


solution

很简单的题

你就考虑实际上是对每一个边求出两端节点分别在两个子树里面的附加边的数量

然后这个值是0第二次随便切有m种方案,如果这个值是1第二次只有一种方案

如果这个值是2或者更大没有方案

然后就可以直接统计答案了

那么就对每一次查询的边

在两个节点++,lca处-2就可以了


#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
struct Edge {
int v, nxt;
} E[N << 1];
int n, m, ans = 0;
int dep[N], head[N], tot = 0;
int tag[N], fa[N][20]; void add(int u, int v) {
E[++tot] = (Edge) {v, head[u]};
head[u] = tot;
} void dfs(int u, int father) {
dep[u] = dep[father] + 1;
fa[u][0] = father;
for (int i = 1; i <= 18; i++)
fa[u][i] = fa[fa[u][i - 1]][i - 1];
for (int i = head[u]; i; i = E[i].nxt) {
int v = E[i].v;
if (v == father) continue;
dfs(v, u);
}
} int LCA(int u, int v) {
if (dep[u] < dep[v]) swap(u, v);
int delta = dep[u] - dep[v];
for (int i = 18; i >= 0; i--) {
if ((delta >> i) & 1) {
u = fa[u][i];
}
}
if (u == v) return u;
for (int i = 18; i >= 0; i--) {
if (fa[u][i] != fa[v][i]) {
u = fa[u][i];
v = fa[v][i];
}
}
return fa[u][0];
} int solve(int u, int father) {
int sum = tag[u];
for (int i = head[u]; i; i = E[i].nxt) {
int v = E[i].v;
if (v == father) continue;
int w = solve(v, u);
if (w == 1) ans++;
if (w == 0) ans += m;
sum += w;
}
return sum;
}
int main() {
#ifdef dream_maker
freopen("input.txt", "r", stdin);
#endif
scanf("%d %d", &n, &m);
for (int i = 2; i <= n; ++i) {
int u, v;
scanf("%d %d", &u, &v);
add(u, v);
add(v, u);
}
dfs(1, 0);
for (int i = 1; i <= m; ++i) {
int u, v;
scanf("%d %d", &u, &v);
tag[u]++;
tag[v]++;
tag[LCA(u, v)] -= 2;
}
solve(1, 0);
printf("%d", ans);
return 0;
}

随机推荐

  1. 第一届山东省ACM——Phone Number(java)

    Description We know that if a phone number A is another phone number B’s prefix, B is not able to be ...

  2. showModalDialog打开页面有缓存,不走action

    当你设置的弹出网页固定时,ie很可能到临时文件区,下载上次产生的该页面,而没有重新加载,    对于动态加载的页面来说,这样往往产生误会,如没有及时更新数据,也就更不利于开发者测试.所以,你可以采用如 ...

  3. [ZT]Language codes – MFC

    Below is table with all MFC language codes. I think it can be sometimes very useful.  First column c ...

  4. 正式学习React(四) 前序篇

    预热 redux 函数内部包含了大量柯里化函数以及代码组合思想 柯里化函数(curry) 通俗的来讲,可以用一句话概括柯里化函数:返回函数的函数 // example const funcA = (a ...

  5. mysql-关联查询

    MySQL关联查询的三种写法: SELECT * FROM film JOIN film_actor ON (film.film_id = film_actor.film_id);SELECT * F ...

  6. 016_python程序变量抽取配置的几种方式

    一.json配置文件 json文件的互转,如下例子: 配置文件:example.json { "mysql":{ "host":"localhost& ...

  7. Android内嵌PDF预览

    一.在对应模块的build.gradle文件中加入依赖 dependencies { implementation 'com.github.barteksc:android-pdf-viewer:3. ...

  8. spring mvc常用注解总结

    1.@RequestMapping@RequestMappingRequestMapping是一个用来处理请求地址映射的注解(将请求映射到对应的控制器方法中),可用于类或方法上.用于类上,表示类中的所 ...

  9. follow

    public function follow(Request $request, FeedModel $model, FeedRepository $repository) { if (is_null ...

  10. Windows IIS安装php

    [可参考文档:https://docs.microsoft.com/en-us/iis/application-frameworks/scenario-build-a-php-website-on-i ...