小 M 有两个长度为 $$$ n $$$ 且字符集为 $$$\{0, 1\}$$$ 的字符串 $$$ s_1, s_2 $$$。
小 M 希望两个字符串中对应位置字符相同的出现次数尽可能多,即满足 $$$ s_{1,i} = s_{2,i} $$$ 的 $$$ i(1 \leq i \leq n) $$$ 尽可能多。为此小 M 有一个字符串编辑工具,这个工具提供的基本操作是在一个字符串中交换两个 相邻 的字符。为了保持字符串的可辨识性,规定两个字符串中的部分字符不能参与交换。小 M 可以用工具对 $$$ s_1 $$$ 或 $$$ s_2 $$$ 进行多次字符交换,其中可以参与交换的字符能够交换任意多次。
现在小 M 想知道,在使用编辑工具后,两个字符串中对应位置字符相同的出现次数最多能有多少。
$$$\textbf{本题包含多组测试数据。}$$$
输入的第一行包含一个整数 $$$T$$$,表示测试数据的组数。
接下来包含 $$$T$$$ 组数据,每组数据的格式如下:
对于每组测试数据输出一行,包含一个整数,表示对应的答案。
1 6 011101 111010 111010 101101
4
$$$\textbf{【样例 1 解释】}$$$
最开始时,$$$s_1 = \tt{011101}$$$,第 $$$4$$$ 和第 $$$6$$$ 个字符不能参与交换;$$$s_2 = \tt{111010}$$$,第 $$$2$$$ 和第 $$$5$$$ 个字符不能参与交换。
考虑如下操作:先交换 $$$s_{1,1}$$$ 与 $$$s_{1,2}$$$ 得到 $$$s_1 = \tt{101101}$$$,再交换 $$$s_{1,2}$$$ 与 $$$s_{1,3}$$$ 得到 $$$s_1 = \tt{110101}$$$,最后交换 $$$s_{2,3}$$$ 与 $$$s_{2,4}$$$ 得到 $$$s_2 = \tt{110110}$$$。此时 $$$s_1$$$ 与 $$$s_2$$$ 的前 $$$4$$$ 个位置上的字符都是相同的。可以证明不存在更好的方案,故输出 $$$4$$$。
$$$\textbf{【样例 2 解释】}$$$
见附件的 edit/edit2.in 与 edit/edit2.ans。
该样例共有 $$$10$$$ 组测试数据,其中第 $$$i(1 \leq i \leq 10)$$$ 组测试数据满足数据范围中描述的测试点 $$$2i - 1$$$ 的限制。
$$$\textbf{【数据范围】}$$$
对于所有的测试数据,保证:$$$1 \leq T \leq 10$$$,$$$1 \leq n \leq 10^5$$$。
| 测试点编号 | $$$n\leq$$$ | 特殊性质 |
| $$$1\sim 4$$$ | $$$10$$$ | 无 |
| $$$5,6$$$ | $$$10^3$$$ | A |
| $$$7,8$$$ | $$$10^5$$$ | A |
| $$$9,10$$$ | $$$10^3$$$ | B |
| $$$11,12$$$ | $$$10^5$$$ | B |
| $$$13,14$$$ | $$$10^3$$$ | C |
| $$$15,16$$$ | $$$10^5$$$ | C |
| $$$17,18$$$ | $$$10^3$$$ | 无 |
| $$$19,20$$$ | $$$10^5$$$ | 无 |
小 F 有 $$$n$$$ 个变量 $$$x_1, x_2, \ldots , x_n$$$。每个变量可以取 $$$1$$$ 至 $$$v$$$ 的整数取值。
小 F 在这 $$$n$$$ 个变量之间添加了 $$$n - 1$$$ 条二元限制,其中第 $$$i$$$($$$1 \leq i \leq n - 1$$$)条限制为:若 $$$x_i = a_i$$$,则要求 $$$x_{i+1} = b_i$$$,且 $$$a_i$$$ 与 $$$b_i$$$ 为 $$$1$$$ 到 $$$v$$$ 之间的整数;当 $$$x_i \neq a_i$$$ 时,第 $$$i$$$ 条限制对 $$$x_{i+1}$$$ 的值不做任何约束。除此之外,小 F 还添加了 $$$m$$$ 条一元限制,其中第 $$$j$$$($$$1 \leq j \leq m$$$)条限制为:$$$x_{c_j} = d_j$$$。
小 F 记住了所有 $$$c_j$$$ 和 $$$d_j$$$ 的值,但把所有 $$$a_i$$$ 和 $$$b_i$$$ 的值都忘了。同时小 F 知道:存在给每一个变量赋值的方案同时满足所有这些限制。
现在小 F 想知道,有多少种 $$$a_i, b_i$$$($$$1 \leq i \leq n - 1$$$)取值的组合,使得能够确保至少存在一种给每个变量 $$$x_i$$$ 赋值的方案可以同时满足所有限制。由于方案数可能很大,小 F 只需要你输出方案数对 $$$10^9 + 7$$$ 取模的结果。
本题包含多组测试数据。
输入的第一行包含一个整数 $$$T$$$,表示测试数据的组数。
接下来包含 $$$T$$$ 组数据,每组数据的格式如下:
第一行包含三个整数 $$$n, m, v$$$,分别表示变量个数、一元限制个数和变量的取值上限。
接下来 $$$m$$$ 行,第 $$$j$$$ 行包含两个整数 $$$c_j, d_j$$$,描述一个一元限制。
对于每组测试数据输出一行,包含一个整数,表示方案数对 $$$10^9 + 7$$$ 取模的结果。
3 2 1 2 1 1 2 2 2 1 1 2 2 2 2 2 1 1 1 2
4 3 0
【样例 1 解释】
见选手目录下的 'assign/assign2.in' 与 'assign/assign2.ans'。
该样例共有 $$$10$$$ 组测试数据,其中第 $$$i$$$($$$1 \leq i \leq 10$$$)组测试数据满足数据范围中描述的测试点 $$$i$$$ 的限制。
【样例 3】
见选手目录下的 'assign/assign3.in' 与 'assign/assign3.ans'。
该样例共有 $$$10$$$ 组测试数据,其中第 $$$i$$$($$$1 \leq i \leq 10$$$)组测试数据满足数据范围中描述的测试点 $$$i + 10$$$ 的限制。
【数据范围】
对于所有的测试数据,保证:
| 测试点 | $$$n \leq$$$ | $$$m \leq$$$ | $$$v \leq$$$ | 特殊性质 |
| $$$1, 2$$$ | $$$6$$$ | $$$6$$$ | $$$2$$$ | 无 |
| $$$3$$$ | $$$9$$$ | $$$9$$$ | $$$2$$$ | 无 |
| $$$4, 5$$$ | $$$12$$$ | $$$12$$$ | $$$2$$$ | 无 |
| $$$6$$$ | $$$10^3$$$ | $$$1$$$ | $$$10^3$$$ | 无 |
| $$$7$$$ | $$$10^5$$$ | $$$1$$$ | $$$10^5$$$ | 无 |
| $$$8,9$$$ | $$$10^9$$$ | $$$1$$$ | $$$10^9$$$ | 无 |
| $$$10$$$ | $$$10^3$$$ | $$$10^3$$$ | $$$10^3$$$ | A |
| $$$11$$$ | $$$10^4$$$ | $$$10^4$$$ | $$$10^4$$$ | A |
| $$$12$$$ | $$$10^5$$$ | $$$10^5$$$ | $$$10^5$$$ | A |
| $$$13$$$ | $$$10^4$$$ | $$$10^3$$$ | $$$10^4$$$ | B |
| $$$14$$$ | $$$10^6$$$ | $$$10^4$$$ | $$$10^6$$$ | B |
| $$$15, 16$$$ | $$$10^9$$$ | $$$10^5$$$ | $$$10^9$$$ | B |
| $$$17$$$ | $$$10^4$$$ | $$$10^3$$$ | $$$10^4$$$ | 无 |
| $$$18$$$ | $$$10^6$$$ | $$$10^4$$$ | $$$10^6$$$ | 无 |
| $$$19, 20$$$ | $$$10^9$$$ | $$$10^5$$$ | $$$10^9$$$ | 无 |
特殊性质 A:保证 $$$m = n$$$,且对于任意的 $$$j$$$($$$1 \leq j \leq m$$$),都有 $$$c_j = j$$$。
特殊性质 B:保证 $$$d_j = 1$$$。
小 Q 是一个算法竞赛初学者,正在学习图论知识中的树的遍历。一棵由 $$$n$$$ 个结点,$$$n - 1$$$ 条边构成的树,初始时所有结点都未被标记,它的遍历过程如下:
1. 选择一个结点 $$$s$$$ 作为遍历起始结点,并把该结点打上标记。 2. 假设当前访问的结点为 $$$u$$$,寻找任意一个与 $$$u$$$ 相邻且未标记的结点 $$$v$$$,将 $$$v$$$ 作为新的当前访问结点并打上标记。之后再次进入第 $$$2$$$ 步。 3. 假设在第 $$$2$$$ 步中,与 $$$u$$$ 相邻的结点都已被标记,如果 $$$u = s$$$ 则遍历过程结束,否则将 $$$u$$$ 设为遍历 $$$u$$$ 之前的上一个结点并再进入第 $$$2$$$ 步。
作为一个奇思妙想的学生,小 Q 在学习完上述知识后不满足于以结点为基础的遍历方式,于是开始研究以边为基础的遍历方式。定义两条边**相邻**,当且仅当它们有一个公共的结点。初始时,所有的边都未被标记。这种以边为基础的遍历过程如下:
现在小 Q 在 $$$n - 1$$$ 条边中选择了 $$$k$$$ 条关键边。小 Q 想知道,以任意一条关键边作为起始遍历边,通过上述遍历过程能够生成多少种不同的新树。这里两棵树被认为是不同的,当且仅当至少存在某一对新的结点,它们仅在其中一棵树中连有新边。
由于结果可能很大,你只需要输出其对 $$$10^9+7$$$ 取模的结果即可。
本题有多组测试数据。
输入的第一行包含两个整数 $$$c, T$$$,表示测试点的编号和测试数据的组数。在样例中,$$$c$$$ 表示该样例与测试点 $$$c$$$ 的数据范围相同。
接下来包含 $$$T$$$ 组数据,每组数据的格式如下:
对于每组测试数据输出一行,包含一个整数,表示结果对 $$$10^9 + 7$$$ 取模的结果。
1 1 4 1 1 2 2 3 2 4 1
2
7 1 5 2 1 2 1 3 2 4 2 5 1 3
3
【样例 1 解释】
两种可能的新树如下:
三种可能的新树如下:
见附件的 traverse/traverse3.in 与 traverse/traverse3.ans。
该组样例满足 $$$c = 4$$$。
【样例 4】
见附件的 traverse/traverse4.in 与 traverse/traverse4.ans。
该组样例满足 $$$c = 7$$$。
【样例 5】
见附件的 traverse/traverse5.in 与 traverse/traverse5.ans。
该组样例满足 $$$c = 11$$$。
【样例 6】
见附件的 traverse/traverse6.in 与 traverse/traverse6.ans。
该组样例满足 $$$c = 13$$$。
【样例 7】
见附件的 traverse/traverse7.in 与 traverse/traverse7.ans。
该组样例满足 $$$c = 15$$$。
【样例 8】
见附件的 traverse/traverse8.in 与 traverse/traverse8.ans。
该组样例满足 $$$c = 16$$$。
【样例 9】
见附件的 traverse/traverse9.in 与 traverse/traverse9.ans。
该组样例满足 $$$c = 18$$$。
【样例 10】
见附件的 traverse/traverse10.in 与 traverse/traverse10.ans。
该组样例满足 $$$c = 19$$$。
【样例 11】
见附件的 traverse/traverse11.in 与 traverse/traverse11.ans。
该组样例满足 $$$c = 22$$$。
【样例 12】
见附件的 traverse/traverse12.in 与 traverse/traverse12.ans。
该组样例满足 $$$c = 24$$$。
【数据范围】
对于所有的测试数据,保证:
| 测试点编号 | $$$n$$$ | $$$k$$$ | 特殊性质 |
| $$$1\sim 3$$$ | $$$\leq 5$$$ | $$$\leq 1$$$ | 无 |
| $$$4\sim 6$$$ | $$$\leq 10^5$$$ | $$$\leq 1$$$ | 无 |
| $$$7\sim 10$$$ | $$$\leq 10^5$$$ | $$$\leq 2$$$ | 无 |
| $$$11,12$$$ | $$$\leq 500$$$ | $$$\leq 8$$$ | 无 |
| $$$13,14$$$ | $$$\leq 10^2$$$ | $$$\lt n$$$ | 无 |
| $$$15$$$ | $$$\leq 500$$$ | $$$\lt n$$$ | 无 |
| $$$16,17$$$ | $$$\leq 10^5$$$ | $$$\leq 500$$$ | 无 |
| $$$18$$$ | $$$\leq 10^5$$$ | $$$\lt n$$$ | A |
| $$$19\sim 21$$$ | $$$\leq 10^5$$$ | $$$\lt n$$$ | B |
| $$$22,23$$$ | $$$\leq 2\times 10^4$$$ | $$$\lt n$$$ | 无 |
| $$$24,25$$$ | $$$\leq 10^5$$$ | $$$\lt n$$$ | 无 |
数据输入的规模可能较大,请选手注意输入读取方式的效率。
有一天小 S 和她的朋友小 N 一起研究一棵包含了 $$$n$$$ 个结点的树。
这是一棵有根树,根结点编号为 $$$1$$$,每个结点 $$$u$$$ 的深度 $$$\text{dep}_ u$$$ 定义为 $$$u$$$ 到 $$$1$$$ 的简单路径上的**结点数量**。
除此之外,再定义 $$$\text{LCA*}(l, r)$$$ 为编号在 $$$[l, r]$$$ 中所有结点的最近公共祖先,即 $$$l, l + 1, \dots , r$$$ 的公共祖先结点中深度最大的结点。
小 N 对这棵树提出了 $$$q$$$ 个询问。在每个询问中,小 N 都会给出三个参数 $$$l, r, k$$$,表示他想知道 $$$[l, r]$$$ 中任意长度大于等于 $$$k$$$ 的连续子区间的最近公共祖先深度的最大值,即
$$$$$$\max_{l\le l'\le r'\le r \land r'-l'+1\ge k}\text{dep}_ {\text{LCA*}(l', r')}$$$$$$
你的任务是帮助小 S 来回答这些询问。
输入的第一行包含一个正整数 $$$n$$$,表示树的结点数。
接下来 $$$n - 1$$$ 行,每行包含两个正整数 $$$u, v$$$,表示存在一条从结点 $$$u$$$ 到结点 $$$v$$$ 的边。
第 $$$n + 1$$$ 行包含一个正整数 $$$q$$$,表示询问的数量。
接下来 $$$q$$$ 行,每行包含三个正整数 $$$l, r, k$$$,描述了一次询问。
对于每次询问输出一行,包含一个整数,表示对应的答案。
6 5 6 6 1 6 2 2 3 2 4 3 2 5 2 1 4 1 1 6 3
3 4 3
【样例 1 解释】

见附件的 query/query2.in 与 query/query2.ans。
该样例满足 $$$n, q ≤ 500$$$。
【样例 3】
见附件的 query/query3.in 与 query/query3.ans。
该样例满足 $$$n, q ≤ 10^5$$$ 且树符合链的形态。
【样例 4】
见附件的 query/query4.in 与 query/query4.ans。
该样例满足 $$$n, q ≤ 5 × 10^5$$$。
【数据范围】
对于所有的测试数据,保证:$$$1 ≤ n, q ≤ 5 × 10^5 , 1 ≤ l ≤ r ≤ n, 1 ≤ k ≤ r - l + 1$$$
| 测试点编号 | $$$n,q\le$$$ | 特殊限制 |
| $$$1\sim2$$$ | $$$500$$$ | 无 |
| $$$3\sim5$$$ | $$$5000$$$ | 无 |
| $$$6\sim9$$$ | $$$10^5$$$ | 满足性质 A |
| $$$10\sim13$$$ | $$$5\times10^5$$$ | 满足性质 A |
| $$$14\sim16$$$ | $$$5\times10^5$$$ | 满足性质 B |
| $$$17\sim20$$$ | $$$10^5$$$ | 无 |
| $$$21\sim25$$$ | $$$5\times10^5$$$ | 无 |
性质 A:保证输入的树符合链的形态,且根结点的度数为 $$$1$$$。
性质 B:对于每个询问保证 $$$k = r - l + 1$$$。