Given a tree
(
is the set of vertices and
is the set
of edges) and a set of pairs of vertices
satisfying for all
,
and
is an ancestor of
on tree
, you are supposed to compute how many functions
(i.e. for each edge
, the value of
would be either
or
) satisfies the condition for any
there exists an edge
on the path from
to
such
that
. Output the answer modulo
.
Input Specification
The first line contains an input
denoting the number of
vertices in tree
. The nodes are numbered from 1 to
and the root
node is node 1. In the following
lines, each line contains two
integers separated by a space
such that
denoting there exists an edge on the tree
between node
and
. There are no guarantees for the direction
of the edge. The following line contains an integer
denoting the
size of
. In the following
lines, each line contains two integers
separated by a space
denoting
. There may be
duplication, or in other words, there might exist some
such
that
and
.
Output Specification
The output contains only an integer denoting the number of
functions
satisfying the condition above.
Sample Input 1
Copy
5
1 2
2 3
3 4
3 5
2
1 3
2 5
Sample Output 1
Copy
10
Sample Input 2
Copy
15
2 1
3 1
4 3
5 2
6 3
7 6
8 4
9 5
10 7
11 5
12 10
13 3
14 9
15 8
6
3 12
5 11
2 5
3 13
8 15
1 13
Sample Output 2
Copy
960
Constraints
For all test cases,
,
.
The input forms a tree, where for all
,
is the ancestor of
.
Test Case | data:image/s3,"s3://crabby-images/934fa/934fa04822e8ca73efc96e34e37c525955ee95ff" alt="n" | data:image/s3,"s3://crabby-images/3f34f/3f34f618c4d2420d1ce1291208ab67a069db2b05" alt="m" | Additional Constraints |
1 | data:image/s3,"s3://crabby-images/f6f1b/f6f1b1f60417febf5d3f4390467f5d5196e5332b" alt="\le 10" | data:image/s3,"s3://crabby-images/f6f1b/f6f1b1f60417febf5d3f4390467f5d5196e5332b" alt="\le 10" | None. |
2 |
3 |
4 |
5 | data:image/s3,"s3://crabby-images/88f59/88f596b1c60d34c08aec627d8bca7c5ac6ce4d6d" alt="\le 500" | data:image/s3,"s3://crabby-images/36e09/36e09b82d234c0989b8766a9fb86b8c339c2b6f3" alt="\le 15" |
6 | data:image/s3,"s3://crabby-images/2ab02/2ab0252dc262ad69d67ece9f337a4e45056b7d9f" alt="\le 10\,000" | data:image/s3,"s3://crabby-images/f6f1b/f6f1b1f60417febf5d3f4390467f5d5196e5332b" alt="\le 10" |
7 | data:image/s3,"s3://crabby-images/eb308/eb308967cf8c61bd8af98f94559282b6bf9507dc" alt="\le 100\,000" | data:image/s3,"s3://crabby-images/3d1e4/3d1e42c028f2af729facf9de2715bd55a74b74ff" alt="\le 16" |
8 | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" |
9 | data:image/s3,"s3://crabby-images/eb308/eb308967cf8c61bd8af98f94559282b6bf9507dc" alt="\le 100\,000" | data:image/s3,"s3://crabby-images/e952b/e952b05a298fa0bff2cc93b49c011616f2786331" alt="\le 22" |
10 | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" |
11 | data:image/s3,"s3://crabby-images/8ac14/8ac14a37e3a5bd929a54d294dbfe1754eb21de62" alt="\le 600" | data:image/s3,"s3://crabby-images/8ac14/8ac14a37e3a5bd929a54d294dbfe1754eb21de62" alt="\le 600" |
12 | data:image/s3,"s3://crabby-images/72fb0/72fb00ee4ca828422443e072265d5597607349a4" alt="\le 1000" | data:image/s3,"s3://crabby-images/72fb0/72fb00ee4ca828422443e072265d5597607349a4" alt="\le 1000" |
13 | data:image/s3,"s3://crabby-images/536b5/536b5a6aa7c8f9b91d9423fe4ed6785fd16fde38" alt="\le 2000" | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" |
14 |
15 | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" | data:image/s3,"s3://crabby-images/536b5/536b5a6aa7c8f9b91d9423fe4ed6785fd16fde38" alt="\le 2000" |
16 |
17 | data:image/s3,"s3://crabby-images/eb308/eb308967cf8c61bd8af98f94559282b6bf9507dc" alt="\le 100\,000" | data:image/s3,"s3://crabby-images/eb308/eb308967cf8c61bd8af98f94559282b6bf9507dc" alt="\le 100\,000" | See below. |
18 |
19 | data:image/s3,"s3://crabby-images/01115/0111546365b8d1ab12b0c5c00791fd45d1e79690" alt="\le 50\,000" | None. |
20 | data:image/s3,"s3://crabby-images/68985/689855ca302698d71faf1b88170f8469cefc8662" alt="\le 80\,000" |
21 | data:image/s3,"s3://crabby-images/eb308/eb308967cf8c61bd8af98f94559282b6bf9507dc" alt="\le 100\,000" | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" |
22 |
23 | data:image/s3,"s3://crabby-images/ae597/ae5978c080bafb917e3a0de5ee41addcc8840c79" alt="\le 500\,000" |
24 |
25 |
In this problem, a perfect binary tree is a binary tree such that each
non-leaf node has two children and the depths of all leaf nodes are the
same; if we number the nodes in a perfect binary tree from up to down,
from left to right, the tree formed by the nodes with smallest numbers
form a complete binary tree. Test cases 17 and 18 are complete binary
trees.
Comments