Submission #3016170


Source Code Expand

import sys
sys.setrecursionlimit(10**8)
N=int(input())
table=[set() for i in range(N)]
L=[]
for i in range(N-1):
    a,b=map(int,input().split())
    table[a-1].add(b-1)
    table[b-1].add(a-1)
    L.append((a-1,b-1))
#mod table!
mod=10**9+7
frac=[1]*(N+2)
rfrac=[1]*(N+2)
s=1
t=1
for i in range(2,N+2):
    s*=i
    s%=mod
    frac[i]=s
    t*=pow(i,mod-2,mod)
    t%=mod
    rfrac[i]=t
#Tree dp
def count(granpa,parent):
    for i in table[parent]:
        if i==granpa:
            continue
        count(parent,i)
    for i in table[parent]:
        if i==granpa:
            continue
        vn[granpa][parent]+=1+vn[parent][i]
    dp[granpa][parent]*=frac[vn[granpa][parent]]
    for i in table[parent]:
        if i==granpa:
            continue
        dp[granpa][parent]*=rfrac[vn[parent][i]+1]*dp[parent][i]
        dp[granpa][parent]%=mod
    return vn[granpa][parent],dp[granpa][parent]
#answer
ans=0
for x,y in L:
    dp=[[1]*N for i in range(N)]
    vn=[[0]*N for i in range(N)]
    a,b=count(x,y)
    dp=[[1]*N for i in range(N)]
    vn=[[0]*N for i in range(N)]
    c,d=count(y,x)    
    s=frac[a+c]
    s*=rfrac[a]*rfrac[c]
    s%=mod
    s*=b*d
    s%=mod
    ans+=s
    ans%=mod
print(ans)

Submission Info

Submission Time
Task N - 木
User okumura
Language PyPy3 (2.4.0)
Score 0
Code Size 1265 Byte
Status TLE
Exec Time 2126 ms
Memory 362328 KB

Judge Result

Set Name All
Score / Max Score 0 / 5
Status
AC × 2
TLE × 7
Set Name Test Cases
All 00, 01, 02, 03, 04, 05, 06, 90, 91
Case Name Status Exec Time Memory
00 TLE 2126 ms 362328 KB
01 TLE 2116 ms 223308 KB
02 TLE 2117 ms 222240 KB
03 TLE 2115 ms 191756 KB
04 TLE 2115 ms 210852 KB
05 TLE 2118 ms 222896 KB
06 TLE 2117 ms 224280 KB
90 AC 166 ms 38256 KB
91 AC 164 ms 38256 KB