#include using namespace std; typedef long long ll; typedef unsigned long long ull; typedef pair P; #define fi first #define se second #define repl(i,a,b) for(ll i=(ll)(a);i<(ll)(b);i++) #define rep(i,n) repl(i,0,n) #define all(x) (x).begin(),(x).end() #define dbg(x) cout<<#x"="<y?x:y) #define mmin(x,y) (x g[5001]; void dfs(int v,int pre){ cnt[v]=1; for(int nv : g[v]){ if(nv==pre)continue; dfs(nv,v); cnt[v]+=cnt[nv]; } int crt=0,nxt=1; rep(j,cnt[v]+1)dp2[crt][j]=0; dp2[crt][0]=1; for(int nv : g[v]){ if(nv==pre)continue; rep(j,cnt[v]+1)dp2[nxt][j]=0; rep(j,cnt[v]+1){ if(dp2[crt][j]==0)break; rep(k,cnt[nv]+1){ if(j+k