#4784. [GESP202506八级] 遍历计数

[GESP202506八级] 遍历计数

当前没有测试数据。

题目描述

给定一棵有 n n 个结点的树 T T ,结点依次以 1,2,,n 1, 2, \ldots, n 标号。树 T T 的深度优先遍历序可由以下过程得到:

  1. 选定深度优先遍历的起点 s s 1sn 1 \leq s \leq n ),当前所在结点即是起点。
  2. 若当前结点存在未被遍历的相邻结点 u u ,则遍历 u u (即令当前所在结点为 u u 并重复这一步);否则回溯。
  3. 按照遍历结点的顺序依次写下结点编号,即可得到一组深度优先遍历序。

由于起点的选择和遍历相邻结点的顺序是任意的,因此对于同一棵树 T T 可能有多组不同的深度优先遍历序。请你求出树 T T 有多少组不同的深度优先遍历序。由于答案可能很大,你只需要求出答案对 109 10^9 取模之后的结果。

输入格式

第一行,一个整数 n n ,表示树 T T 的结点数。

接下来 n1 n-1 行,每行两个正整数 ui,vi u_i, v_i ,表示树 T T 中的一条连接结点 ui,vi u_i, v_i 的边。

输出格式

输出一行,一个整数,表示树 T T 的不同的深度优先遍历序数量对 109 10^9 取模的结果。

4
1 2
2 3
3 4
6
8
1 2
1 3
1 4
2 5
2 6
3 7
3 8
112

数据范围

测试点分类 占比 数据范围 特殊性质
1 40% 1n8 1 \leq n \leq 8 -
2 20% 1n105 1 \leq n \leq 10^5 给定的树是一条链
3 40% -

对于所有测试点,保证 1n105 1 \leq n \leq 10^5