树链剖分 关于点权与边权的转换

因为是一棵树,可以直接把 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);

 

posted @ 2019-07-17 14:37  shuai_hui  阅读(897)  评论(0编辑  收藏  举报