树链剖分 关于点权与边权的转换
因为是一棵树,可以直接把 u点和v点间(假设u为父节点,v为子节点)的边 的边权往下给v点
这样就转换成了点权,那么此时查询 u点到v点之间路径的权值和 的话
由于u点存有 u的父节点到u 的边权,所以应该查询的是 u到v的路径上 的第二个点到v的权值和
修改查询树上两结点间路径长度的函数 int queryPath(int x,int y){ } 中求最后一步的部分 /// 点权版本 if(p[x]>p[y]) swap(x,y); return ans+query(p[x],p[y],1,pos,1); /// 边权版本 if(x==y) return ans; if(dep[x]>dep[y]) swap(x,y); return ans+query(p[son[x]],p[y],root);