1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
#include <cstdio> #include <algorithm> #include <cstring> #include <cmath> #define maxn 110 #define maxm 210 #define rep(i, l, r) for (int i = l; i <= r; i++) #define per(i, r, l) for (int i = r; i >= l; i--) #define ll long long using namespace std; int read() { int p = 0, f = 1; char c = getchar(); while (c < 48 || c > 57) { if (c == '-') f = -1; c = getchar(); } while (c >= 48 && c <= 57) p = (p << 1) + (p << 3) + (c ^ 48), c = getchar(); return p * f; } const int mod = 1e9 + 7; struct edge { int v, nxt; } e[maxm]; int cnt[maxn], head[maxn], tot; void init() { tot = 0; memset(e, 0, sizeof(e)); memset(head, 0, sizeof(head)); } void add(int u, int v) { e[++tot].v = v; e[tot].nxt = head[u]; head[u] = tot; } void dfs(int u, int fu, int d) { cnt[d]++; for (int i = head[u]; i; i = e[i].nxt) { int v = e[i].v; if (v == fu) continue; dfs(v, u, d + 1); } } int dp[maxn][maxn]; int main() { int t = read(); while (t--) { int n = read(), k = read(); init(); rep(i, 1, n - 1) { int u = read(), v = read(); add(u, v), add(v, u); } if (k == 2) { printf("%lld\n", n * (n - 1ll) / 2 % mod); continue; } ll ans = 0; for (int u = 1; u <= n; u++) { memset(dp, 0, sizeof(dp)); for (int i = 1; i < n; i++) dp[i][0] = 1; for (int i = head[u]; i; i = e[i].nxt) { memset(cnt, 0, sizeof(cnt)); int v = e[i].v; dfs(v, u, 1); for (int i = 1; i < n; i++) { if (cnt[i] == 0) break; per(j, k, 1) { dp[i][j] = 1ll * (dp[i][j] + dp[i][j - 1] * cnt[i]) % mod; } } } for (int i = 1; i <= n; i++) ans = (ans + dp[i][k]) % mod; } printf("%lld\n", ans); } return 0; }
|
Gitalk 加载中 ...