CF599E Sandy and Nuts
Description
Rooted tree is a connected graph without any simple cycles with one vertex selected as a root. In this problem the vertex number $ 1 $ will always serve as a root.
Lowest common ancestor of two vertices $ u $ and $ v $ is the farthest from the root vertex that lies on both the path from $ u $ to the root and on path from $ v $ to the root. We will denote it as $ LCA(u,v) $ .
Sandy had a rooted tree consisting of $ n $ vertices that she used to store her nuts. Unfortunately, the underwater storm broke her tree and she doesn't remember all it's edges. She only managed to restore $ m $ edges of the initial tree and $ q $ triples $ a_{i} $ , $ b_{i} $ and $ c_{i} $ , for which she supposes $ LCA(a_{i},b_{i})=c_{i} $ .
Help Sandy count the number of trees of size $ n $ with vertex $ 1 $ as a root, that match all the information she remembered. If she made a mess and there are no such trees then print $ 0 $ . Two rooted trees are considered to be distinct if there exists an edge that occur in one of them and doesn't occur in the other one.
Input Format
N/A
Output Format
N/A
Explanation/Hint
In the second sample correct answer looks like this:
data:image/s3,"s3://crabby-images/a8a38/a8a3838d5615ee45662827781fc50c460073f139" alt=""In the third sample there are two possible trees:
data:image/s3,"s3://crabby-images/3f1b7/3f1b754804d44de7233f046a8976e77dffa72c23" alt="" data:image/s3,"s3://crabby-images/0f349/0f349e8b40020b32d76a2da999700df65064ee2c" alt=""In the fourth sample the answer is $ 0 $ because the information about $ LCA $ is inconsistent.