Problem10766--ABC140 - F - Many Slimes

10766: ABC140 - F - Many Slimes

[Creator : ]
Time Limit : 1.000 sec  Memory Limit : 512 MiB

Description

We have one slime.

You can set the _health_ of this slime to any integer value of your choice.

A slime reproduces every second by spawning another slime that has strictly less health. You can freely choose the health of each new slime. The first reproduction of our slime will happen in one second.

Determine if it is possible to set the healths of our first slime and the subsequent slimes spawn so that the multiset of the healths of the $2^N$ slimes that will exist in $N$ seconds equals a multiset $S$.

Here $S$ is a multiset containing $2^N$ (possibly duplicated) integers: $S_1,~S_2,~...,~S_{2^N}$.

Input

Input is given from Standard Input in the following format:

```
$N$
$S_1$ $S_2$ $...$ $S_{2^N}$
```

Output

If it is possible to set the healths of the first slime and the subsequent slimes spawn so that the multiset of the healths of the $2^N$ slimes that will exist in $N$ seconds equals $S$, print `Yes`; otherwise, print `No`.

Constraints

-   All values in input are integers.
-   $1 \leq N \leq 18$
-   $1 \leq S_i \leq 10^9$

Sample 1 Input

2
4 2 3 1

Sample 1 Output

Yes

We will show one way to make the multiset of the healths of the slimes that will exist in $2$ seconds equal to $S$.

First, set the health of the first slime to $4$.

By letting the first slime spawn a slime whose health is $3$, the healths of the slimes that exist in $1$ second can be $4,~3$.

Then, by letting the first slime spawn a slime whose health is $2$, and letting the second slime spawn a slime whose health is $1$, the healths of the slimes that exist in $2$ seconds can be $4,~3,~2,~1$, which is equal to $S$ as multisets.

Sample 2 Input

2
1 2 3 1

Sample 2 Output

Yes
$S$ may contain multiple instances of the same integer.

Sample 3 Input

1
1 1

Sample 3 Output

No

5
4 3 5 3 1 2 7 8 7 4 6 3 7 2 3 6 2 7 3 2 6 7 3 4 6 7 3 4 2 5 2 3

No

Source/Category