...Then Vadim rearranged the problems as he needed to and...
The most difficult part of the jury’s work, besides coming up with problems, writing correct solutions, creating checkers, validators, tests, statements, and editorials, is arranging the problems among themselves in an already prepared set. Nobody knows how to do it correctly, so an ancient technique is used for this.
This secret knowledge consists of a simple algorithm:

First, each problem in the set is sorted by difficulty, with the most difficult one assigned 1, the second most difficult assigned 2, and so on.

Then a template is taken — some permutation of numbers from 1 to N, where N is the number of problems in the contest, which determines the arrangement of problems by difficulty.

After that, a left subtemplate and a right subtemplate are found. To do this, the position of the most difficult problem is determined in the template. Then the left subtemplate is the subtemplate responsible for all the problems that come before the most difficult one (if the most difficult problem was the first in the template, it becomes empty), and the right subtemplate is the subtemplate responsible for all the problems that come after the most difficult one (if the most difficult problem was the last in the template, it also becomes empty).

Two templates are called equivalent if they are both empty, or if the position of the most difficult problem is the same in both templates, their left subtemplates are equivalent, and their right subtemplates are also equivalent.

And the final step for arranging the problems in the contest is to choose an arbitrary template equivalent to the one given initially.
There is one problem with this. The jury always used the same ancient template, and it is time to change it, but to do that, the number of templates equivalent to it needs to be calculated. The jury is currently busy rearranging problems in another contest and answering participants’ questions, so this task falls to you.
Input
The first line contains a single integer N — the number of problems in the set (1 ≤ N ≤ 10^{5}).
The second line contains N integers p_{i} separated by spaces — the description of the template you are checking (1 ≤ p_{i} ≤ N, all p_{i} are distinct).
Output
Print the number of templates equivalent to the given one, modulo 10^{9}+7. In other words, find the remainder when the number of templates is divided by 1 000 000 007.
Samples
input  output 

3
2 1 3
 2

12
12 5 3 11 2 8 4 9 1 6 10 7
 34650

Notes
In the first example, there are only two templates equivalent to the input template — (2,1,3) and (3,1,2).
Problem Author: Vadim Barinov
Problem Source: Ural School Programming Contest 2021