Problem B
Ceiling Function
Advanced Ceiling Manufacturers (ACM) is analyzing the
properties of its new series of Incredibly Collapse-Proof
Ceilings (ICPCs). An ICPC consists of
To be precise, ACM takes the collapse-resistance values for
the layers, ordered from the top layer to the bottom layer, and
inserts them one-by-one into a tree. The rules for inserting a
value
-
If the tree is empty, make
the root of the tree. -
If the tree is not empty, compare
with the root of the tree. If is smaller, insert into the left subtree of the root, otherwise insert into the right subtree.
ACM has a set of ceiling prototypes it wants to analyze by trying to collapse them. It wants to take each group of ceiling prototypes that have trees of the same shape and analyze them together.
For example, assume ACM is considering five ceiling prototypes with three layers each, as described by Sample Input 1 and shown in Figure 1. Notice that the first prototype’s top layer has collapse-resistance value 2, the middle layer has value 7, and the bottom layer has value 1. The second prototype has layers with collapse-resistance values of 3, 1, and 4 – and yet these two prototypes induce the same tree shape, so ACM will analyze them together.
Given a set of prototypes, your task is to determine how many different tree shapes they induce.
![\includegraphics[width=0.9\textwidth ]{shape.pdf}](/problems/ceiling/file/statement/en/img-0001.png)
Input
The first line of the input contains two integers
The next
Output
Display the number of different tree shapes.
Sample Input 1 | Sample Output 1 |
---|---|
5 3 2 7 1 3 1 4 1 5 9 2 6 5 9 7 3 |
4 |
Sample Input 2 | Sample Output 2 |
---|---|
3 4 3 1 2 40000 3 4 2 1 33 42 17 23 |
2 |