Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

F. Progress Monitoring

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputProgramming teacher Dmitry Olegovich is going to propose the following task for one of his tests for students:

You are given a tree *T* with *n* vertices, specified by its adjacency matrix *a*[1... *n*, 1... *n*]. What is the output of the following pseudocode?

used[1 ... n] = {0, ..., 0};

procedure dfs(v):

print v;

used[v] = 1;

for i = 1, 2, ..., n:

if (a[v][i] == 1 and used[i] == 0):

dfs(i);

dfs(1);

In order to simplify the test results checking procedure, Dmitry Olegovich decided to create a tree *T* such that the result is his favorite sequence *b*. On the other hand, Dmitry Olegovich doesn't want to provide students with same trees as input, otherwise they might cheat. That's why Dmitry Olegovich is trying to find out the number of different trees *T* such that the result of running the above pseudocode with *T* as input is exactly the sequence *b*. Can you help him?

Two trees with *n* vertices are called different if their adjacency matrices *a*_{1} and *a*_{2} are different, i. e. there exists a pair (*i*, *j*), such that 1 ≤ *i*, *j* ≤ *n* and *a*_{1}[*i*][*j*] ≠ *a*_{2}[*i*][*j*].

Input

The first line contains the positive integer *n* (1 ≤ *n* ≤ 500) — the length of sequence *b*.

The second line contains *n* positive integers *b*_{1}, *b*_{2}, ..., *b*_{n} (1 ≤ *b*_{i} ≤ *n*). It is guaranteed that *b* is a permutation, or in other words, each of the numbers 1, 2, ..., *n* appears exactly once in the sequence *b*. Also it is guaranteed that *b*_{1} = 1.

Output

Output the number of trees satisfying the conditions above modulo 10^{9} + 7.

Examples

Input

3

1 2 3

Output

2

Input

3

1 3 2

Output

1

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/30/2017 23:33:11 (p1).

Desktop version, switch to mobile version.
User lists

Name |
---|