Hide

Greedy Increasing Subsequences

Jimmy’s homework is to find a long increasing subsequence of a given sequence $a_1, a_2, \ldots , a_ n$. But the sequence is really long! Jimmy doesn’t know how to do this effectively.

So Jimmy takes a greedy approach. He begins by picking the first number in the sequence. Then he repeats the following rule until it no longer applies: pick the next number in the sequence that is bigger than the number he just picked.

More precisely, Jimmy picks the subsequence $a_{i_1}, a_{i_2}, \ldots , a_{i_ k}$ where:

  • $i_1 = 1$

  • For each $1 \leq j < k$, $i_{j+1}$ is the smallest index greater than $i_ j$ such that $a_{i_ j} < a_{i_{j+1}}$

  • $a_{i_ k} \geq a_\ell $ for every $\ell > i_ k$

Jimmy realizes that this may not produce a very long subsequence. So to help him find other subsequences, he removes $a_{i_1}, a_{i_2}, \ldots , a_{i_ k}$ from the given sequence and finds another increasing subsequence using his greedy algorithm on the remaining sequence. He repeats this until he has used up all numbers from the original sequence.

But even this is starting to sound exhausting for Jimmy, so he asks you to help him by finding all of the sequences that would be formed by repeatedly applying the above greedy procedure and removing the resulting subsequence until the given sequence is empty.

Input

The first line of input contains a single integer $n$ ($1 \leq n \leq 2 \times 10^5$) indicating the length of the original sequence.

The second line of input contains $n$ integers $a_1, a_2, \ldots , a_ n$ ($0 \leq a_ i \leq 10^9$).

Output

The first line of output contains the number $s$ of sequences that are produced. The next $s$ lines contain the sequences, the $i$th such line containing the increasing subsequence that is formed in the $i$th application of the greedy algorithm.

Sample Input 1 Sample Output 1
7
2 2 1 5 3 4 6
3
2 5 6
2 3 4
1
Sample Input 2 Sample Output 2
7
8 6 7 5 3 0 9
5
8 9
6 7
5
3
0

Please log in to submit a solution to this problem

Log in