\[ ans1=\sum_{i=1}^{k}size[son[i]]*2+1=size[x]*2-1 \]
\[ ans2=\sum_{i=1}^{k}\sum_{j=1}^{k}size[son[i]]*size[son[j]] \]
\[ ans2=\sum_{i=1}^{k}size[son[i]]*(size[x]-1) \]
\[ ans2=(size[x]-1)^2 \]
\[ ans2=(size[x]-1)^2-\sum_{i=1}^{k}size[i]^2 \]
\[ ans=ans1+ans2=size[x]*2-1+(size[x]-1)^2-\sum_{i=1}^{k}size[i]^1 \]
\[ ans=size[x]^2-\sum_{i=1}^{k}size[i]^2 \]
#include<iostream>
#include<cstring>
#include<cstdio>
#define maxn 10001
#define p 1000000007
using namespace std;
struct edge{
int to,next;
edge(){}
edge(const int &_to,const int &_next){ to=_to,next=_next; }
}e[maxn<<1];
int head[maxn],k;
int size[maxn],ans[maxn];
int n,m,r;
inline int read(){
register int x(0),f(1); register char c(getchar());
while(c<'0'||'9'<c){ if(c=='-') f=-1; c=getchar(); }
while('0'<=c&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
inline void add(const int &u,const int &v){
e[k]=edge(v,head[u]);
head[u]=k++;
}
inline void dfs(int u,int pre){
size[u]=1;
for(register int i=head[u];~i;i=e[i].next){
int v=e[i].to;
if(v==pre) continue;
dfs(v,u),size[u]+=size[v];
ans[u]=(ans[u]+size[v]*size[v])%p;
}
ans[u]=(size[u]*size[u]%p-ans[u]+p)%p;
}
int main(){
memset(head,-1,sizeof head);
n=read(),r=read(),m=read();
for(register int i=1;i<n;i++){
int u=read(),v=read();
add(u,v),add(v,u);
}
dfs(r,0);
while(m--) printf("%d\n",ans[read()]);
return 0;
}
原文:https://www.cnblogs.com/akura/p/10837547.html