題目
分析
套上prufer序列,
對於一顆n個節點度數分別爲
所以答案爲
使
考慮處理
對於多項式
我們考慮
//後面的內容我還不太理解,只能大概講講。如果講錯了,請大佬指出一下錯誤
現在解釋一下最後一條式子
根據指數型生成函數的定義
當
那麼,
那麼當
即爲
#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
#include <map>
const int maxlongint=2147483647;
const long long mo=1e9+7;
const int N=2005;
using namespace std;
long long w[N],ans,f[N],sum,jc[N],ww;
int n;
long long mi(long long x,int y)
{
long long s=1;
for(;y;x=x*x%mo,y>>=1) s=y&1?s*x%mo:s;
return s;
}
int main()
{
scanf("%d",&n);
f[0]=jc[0]=ww=1;
for(int i=1;i<=n;i++)
{
scanf("%lld",&w[i]),sum=(sum+w[i])%mo,jc[i]=jc[i-1]*i%mo,ww=ww*w[i]%mo;
for(int j=i;j>=1;j--) f[j]=(f[j]+f[j-1]*w[i]%mo)%mo;
}
for(int k=0;k<=n-2;k++)
ans=(ans+f[k]*mi(sum,n-2-k)%mo*mi(jc[n-2-k],mo-2)%mo)%mo;
printf("%lld",ans*ww%mo*jc[n-2]%mo);
}