问题6980--清点干草捆

6980: 清点干草捆

[命题人 : ]
时间限制 : 1.000 sec  内存限制 : 256 MiB

题目描述

【题目描述】

如同往常一样,奶牛 Bessie 正在 Farmer John 的牛棚里制造麻烦。FJ  N (1≤N≤5000) 堆草堆。对于每个 i∈[1,N],第 i 堆草堆有 hi1≤hi≤10^9)的草。Bessie 不想让任何的草倒下来,所以她唯一可以执行的操作为:

如果两个相邻的草堆的高度相差恰好为 1,她可以将较高的草堆中最上方的草移到较低的草堆之上。

执行有限多次上述操作后,可以得到多少种不同的高度序列,对 10^9+7 取模?两个高度序列被认为是相同的,如果对于所有 i,第 i 堆草堆在两者中具有相同数量的草。

输入格式(从终端 / 标准输入读入):

输入的第一行包含 T,为独立的子测试用例的数量,必须全部回答正确才能通过整个测试用例。

每个子测试用例包含 N,以及一个 N 个高度的序列。输入保证所有子测试用例的 N 之和不超过 5000

输出格式(输出至终端 / 标准输出):

输出 T 行,每行输出一个子测试用例的答案。

输入样例

7

4

2 2 2 3

4

3 3 1 2

4

5 3 4 2

6

3 3 1 1 2 2

6

1 3 3 4 1 2

6

4 1 2 3 5 4

10

1 5 6 6 6 4 2 3 2 5

输出样例

4

4

5

15

9

8

19

【样例说明】

对于第一个子测试用例,四个可能的高度序列为:

(2,2,2,3),(2,2,3,2),(2,3,2,2),(3,2,2,2).

对于第二个子测试用例,四个可能的高度序列为:

(2,3,3,1),(3,2,3,1),(3,3,2,1),(3,3,1,2).

测试点性质

测试点 1-3 满足 N≤10

测试点 4 满足对于所有 i,有 1≤hi≤3

测试点 5-7 满足对于所有 i,有 |hi−i|≤1

测试点 8-10 满足对于所有 i,有1≤hi≤4,且 N≤100

测试点 11-13 满足 N≤100

测试点 14-17 满足N≤1000

测试点 18-21 没有额外限制。

 

 

来源/分类