求树上任意两个点的距离lca

前言:一开始看到这个题目的时候,感觉就和lca有关,但是没有想到具体的公式

d = d e p [ x ] + d e p [ y ] − 2 ∗ d e p [ l c a ( x , y ) ] d = dep[x] + dep[y] - 2*dep[lca(x,y)] d=dep[x]+dep[y]−2∗dep[lca(x,y)]

并且我们这个题目还是一个进阶版本的题,我们还会存在电缆,我们还有两种选择的可能,这也是要考虑在内的


题目地址

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define ll long long

const int N = (int)5e5;
int n;
int e[N * 2], ne[N * 2], h[N], idx = 0;
int px, py;
int dep[N], fa[N][20];

inline int read()
{
	int x = 0, f = 1;
	char c = getchar();
	while (c < '0' || c>'9') { if (c == '-') f = -1; c = getchar(); }
	while (c >= '0' && c <= '9') x = (x << 1) + (x << 3) + c - '0', c = getchar();
	return f * x;
}

void add(int a, int b) {
	e[++idx] = b, ne[idx] = h[a], h[a] = idx;
}

void dfs(int u, int father) {
	dep[u] = dep[father] + 1;
	fa[u][0] = father;
	for (int i = 1; i < 20; i++) {
		fa[u][i] = fa[fa[u][i - 1]][i - 1];
	}
	for (int i = h[u]; i; i = ne[i]) {
		int to = e[i];
		if (to == father) continue;
		dfs(to, u);
	}
}

int lca(int u, int v) {
	if (dep[u] < dep[v]) swap(u, v);
	// 先跳到同一层
	for (int i = 19; i >= 0; i--) {
		if (dep[fa[u][i]] >= dep[v]) u = fa[u][i];
	}
	if (u == v) return u;
	for (int i = 19; i >= 0; i--) {
		if (fa[u][i] != fa[v][i]) {
			u = fa[u][i], v = fa[v][i];
		}
	}return fa[u][0];
}

int fun(int x, int y) {
	return dep[x] + dep[y] - 2 * dep[lca(x, y)];
}

int main() {
	cin >> n;
	for (int i = 1; i < n; i++) {
		int x, y; 
		//cin >> x >> y;
		x = read(); y = read();
		add(x, y), add(y, x);
	}
	cin >> px >> py;
	int q; cin >> q;
	dfs(1, 0);
	while (q--) {
		int x, y; 
		//cin >> x >> y;
		x = read(); y = read();
		int d = min({ fun(x,y),fun(x,px) + fun(y,py),fun(x,py) + fun(y,px) });
		//cout << d << endl;
		printf("%d\n", d);
	}return 0;
}
相关推荐
Hcoco_me31 分钟前
RTMPose_JSON相关解读
算法·数据挖掘·json·聚类
高洁0141 分钟前
DNN案例一步步构建深层神经网络(二)
人工智能·python·深度学习·算法·机器学习
aini_lovee1 小时前
改进遗传算法求解VRP问题时的局部搜索能力
开发语言·算法·matlab
老蒋新思维1 小时前
反脆弱性设计:创始人IP与AI智能体如何构建愈动荡愈强大的知识商业|创客匠人
人工智能·网络协议·tcp/ip·算法·机器学习·创始人ip·创客匠人
Salt_07281 小时前
DAY 36 官方文档的阅读
python·算法·机器学习·github
明洞日记3 小时前
【VTK手册027】VTK 颜色连续映射:vtkColorTransferFunction 深度解析与实战指南
c++·图像处理·算法·vtk·图形渲染
B_lack0263 小时前
西门子PLC结构化编程_线性插值算法功能块
算法·pid·西门子plc·博途·线性插值·开环控制
fufu03113 小时前
Linux环境下的C语言编程(四十三)
linux·c语言·算法
业精于勤的牙3 小时前
三角形最小路径和(二)
算法
风筝在晴天搁浅3 小时前
hot100 239.滑动窗口最大值
数据结构·算法·leetcode