AtCoder Beginner Contest 160-F - Distributing Integers(DFS&DP)

题目传送门

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll N=2e5+5,mod=1e9+7;
vector<ll>g[N];
ll a[N],n,sz[N],tmp=1; //a[i]表示以结点i为开始点对排列的影响。 
ll ksm(ll a,ll n){ //ksm(快速幂) 
	ll ans=1;
	while(n){
		if(n&1) ans=ans*a%mod;
		a=a*a%mod;
		n>>=1;
	}
	return ans;
}
void dfs(int u,int fa){
	sz[u]=1;
	for(auto v:g[u]){
		if(v!=fa){
			dfs(v,u);
			sz[u]+=sz[v];
		}
	}
	tmp=tmp*sz[u]%mod;//sz[ i ]的连乘 
}
void fun(int u,int fa){ //状态转移方程. 
	 for(auto v:g[u]){
	 	 if(v!=fa){
	 	 	 a[v]=a[u]*ksm(sz[v],mod-2)%mod*(n-sz[v])%mod;
			 fun(v,u);	
		  }
	 }
}
int main(){
	cin>>n; 
	ll jc=1;//jc ( 阶乘 ) 
	for(ll i=2,u,v;i<=n;i++){
		 cin>>u>>v;
		 g[u].push_back(v),g[v].push_back(u);
		 jc=jc*i%mod; 
	}
	dfs(1,0);
	a[1]=tmp;
	fun(1,0); 
		for(int i=1;i<=n;i++)
			printf("%lld\n",jc*ksm(a[i],mod-2)%mod);
	return 0;
}