Subpermutation
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

的排列是一个长度为 的序列,其中从 的每个数字都只出现一次。 的全排列是将 的所有排列按字典顺序连接成一个序列的序列。如果 其中 是满足 的最小索引,则序列p_1,p_2,...,p_n 在字典上小于

以下是此问题中使用的一些符号:

- 的全排列。例如,
- 的所有排列的集合。例如,
- 中等于 的连续子序列的数量。例如,

现在给定,请计算

输入描述:

第一行包含一个整数,表示数据组数。
接下来行,每行包含两个整数,如描述中所述。

输出描述:

对于每组数据,输出
示例1

输入

复制
4
2 1
2 2
3 2
4 3

输出

复制
2
2
4
15

说明

对于第三组数据,p_3 = \{1,2,3,1,3,2,2,1,3,2,3,1,3,1,2,3,2,1\}, S_2=\{\{1,2\},\{2,1\}\}p_3中有4个连续子序列等于\{1,2\}\{2,1\}\{\underline{1,2},3,1,3 ,2,\underline{2,1},3,2,3,1,3,\underline{1,2},3,\underline{2,1}\}

备注:

原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=7133