Mountain Holidays 2
All submissions for this problem are available.
Read problems statements in Mandarin Chinese and Russian.
Let’s remember the problem Mountain holidays (MOU1H). The story of Mountain holidays is the following. Some time ago, Chef discovered that more and more people have started climbing mountains every day. So he decided to build a restaurant in the Ukrainian resort Bukovel (Carpathian Mountains). But there are many places to choose, so he wants to choose the best one.
By your great helps, Chef could find to the best place to build a restaurant, now Chef becomes rich. Now he wants to build a restaurant in the next mountain. Similar to previous one, the next mountain is described by a sequence of N points. Here the points are numbered from 1 to N, and the height of point k is denoted by Hk. Every two adjacent points of the mountain are connected by a segment.
For example, the mountain described by N = 9, H = [0, 2, 1, 2, 1, 3, 0, 1, 0] is like a following:
/\ /\/\/ \ / \/\
In the mountain, all of the tourists will go from the point 1 to point N.
For comfort of the tourists, Chef has bought teleports too. Using a teleport, a tourist can be transferred from point i to point j, for all i < j. Of course, tourists can also walk from point i to point i+1 on foot.
Now Chef wants to calculate the attractiveness of the mountain, as the number of the different climbs.
A climb is defined by the nonempty sequence (p1, p1+1), (p2, p2+1), ..., (ps, ps+1) of the moves on foot , where pk+1 ≤ pk+1 for k = 1, 2, ..., s − 1.Two climbs, say (p1, p1+1), (p2, p2+1), ..., (ps, ps+1) and (q1, q1+1), (q2, q2+1), ..., (qt, qt+1) are different if and only if
- s ≠ t or
- There exists at least one k such that 1 ≤ k < min(s, t) and Hpk+1 – Hpk ≠ Hqk+1 – Hqk.
You are given the array H, find the number of the different climbs that exist on the mountain. Since the answer can be very large, output it modulo 109+9 = 1000000009.
The first line of input contains T, denoting the number of test cases. Then T test cases follow.
The first line of each test case contains an integer N, denoting the number of points on the mountain. On second line of each test case, there are N space-separated integers H1, H2, ..., HN, denoting the height of each point.
For each test case, output an integer denoting the number of the different climbs modulo 109+9 = 1000000009.
- 1 ≤ T ≤ 100000, that is, 1 ≤ T ≤ 105
- 2 ≤ N ≤ 1000000, that is, 2 ≤ N ≤ 106
- Sum of N over all test cases in one file will be at most 1000000 = 106
- -2000000 ≤ Hk ≤ 2000000, that is, −2 × 106 ≤ Hk ≤ 2 × 106
Input 3 6 1 2 3 4 5 6 9 0 2 1 2 1 3 0 1 0 7 0 5 -5 5 -5 4 -4 Output 5 199 55
In the first test case, since height increases by one for each move on foot, there will be one unique climb for each length. So there are 5 climbs with length 1, 2, ..., 5. Here length means the number of moves by foot.
We can get the following 5 distinct climbs.
- (1, 2)
- (1, 2), (2, 3)
- (1, 2), (2, 3), (3, 4)
- (1, 2), (2, 3), (3, 4), (4, 5)
- (1, 2), (2, 3), (3, 4), (4, 5), (5, 6)
The second test case is taken from the problem statement.
Warning: The input and output can be large. Please don't use a slow input/output method.
|Tags||aug14, dynamic-programming, medium, witalij_hq|
|Time Limit:||0.5 sec|
|Source Limit:||50000 Bytes|
|Languages:||C, CPP14, JAVA, PYTH, PYTH 3.5, CS2, PAS fpc, PAS gpc, RUBY, PHP, GO, NODEJS, HASK, SCALA, D, PERL, FORT, WSPC, ADA, CAML, ICK, BF, ASM, CLPS, PRLG, ICON, SCM qobi, PIKE, ST, NICE, LUA, BASH, NEM, LISP sbcl, LISP clisp, SCM guile, JS, ERL, TCL, PERL6, TEXT, CLOJ, FS|
Fetching successful submissions
If you are still having problems, see a sample solution here.