1980.Tree nesting

Time Limit: 1s Memory Limit: 256MB

You are given two trees (connected undirected acyclic graphs) S and T.

Count the number of subtrees (connected subgraphs) of S that are isomorphic to tree T. Since this number can get quite large, output it modulo 109+7.

Two subtrees of tree S are considered different, if there exists a vertex in S that belongs to exactly one of them.

Tree G is called isomorphic to tree H if there exists a bijection f from the set of vertices of G to the set of vertices of H that has the following property: if there is an edge between vertices A and B in tree G, then there must be an edge between vertices f(A) and f(B) in tree H. And vice versa- if there is an edge between vertices A and B in tree H, there must be an edge between f-1(A) and f-1(B) in tree G.

Input Format(From the terminal/stdin)

The first line contains a single integer |S| (1 \le |S| \le 1000) - the number of vertices of tree S.

Next |S|-1 lines contain two integers ui and vi (1 \le ui,vi \le |S|) and describe edges of tree S.

The next line contains a single integer |T| (1 \le |T| \le 12) - the number of vertices of tree T.

Next |T|-1 lines contain two integers xi and yi (1 \le xi,yi \le |T|) and describe edges of tree T.

Output Format(To the terminal/stdout)

On the first line output a single integer - the answer to the given task modulo 109+7.

Sample Input 1

Copy
5
1 2
2 3
3 4
4 5
3
1 2
2 3
 \n
 · \n
 · \n
 · \n
 · \n
 \n
 · \n
 · \n

Sample Output 1

Copy
3
 \n

Sample Input 2

Copy
3
2 3
3 1
3
1 2
1 3
 \n
 · \n
 · \n
 \n
 · \n
 · \n

Sample Output 2

Copy
1
 \n

Sample Input 3

Copy
7
1 2
1 3
1 4
1 5
1 6
1 7
4
4 1
4 2
4 3
 \n
 · \n
 · \n
 · \n
 · \n
 · \n
 · \n
 \n
 · \n
 · \n
 · \n

Sample Output 3

Copy
20
  \n

Sample Input 4

Copy
5
1 2
2 3
3 4
4 5
4
4 1
4 2
4 3
 \n
 · \n
 · \n
 · \n
 · \n
 \n
 · \n
 · \n
 · \n

Sample Output 4

Copy
0
 \n

Submit

请先 登录

© 2025 FAQs