一道比较基础的计数题,还是一个常用的单独计算贡献的例子. 首先看题目和范围,暴力枚举肯定是不可行的,而且\(O(n\ logn)\)的算法貌似很难写. 那我们就来想\(O(n)\)的吧,我们单独考虑每一条边的贡献,我们注意到一个重要的性质: 树上任意两点间的最短路径都是唯一确定的. 这个常识吧,所以我们只需要考虑每一条边两边的点在计算时会经过这条边多少次. 我们枚举每一条边,然后可以这样考虑这一条边: 我们设一边有\(x\)个点,另一边有\(y\)个点,很明显\(x+y=n\) 然后我们考虑有多…